Windows平台编译 PostgreSQL

php中文网
发布: 2016-06-07 17:29:25
原创
1210人浏览过

1、源代码下载与准备 PG 词法和语法解析分别使用 flex 和 yacc脚本,也就是源代码里能看到的 .l 和 .y 文件,由他们生成 .c 和 .

1、源代码下载与准备
pg 词法和语法解析分别使用 flex 和 yacc脚本,也就是源代码里能看到的 .l 和 .y 文件,由他们生成 .c 和 .h文件。
更详细资料见:
(很不幸,这个网站是无法直接访问的,自己想办法)

这两个工具在 windows 下的环境一直没有彻底弄好,再加上考虑它们的版本,我都是在 linux 下生成语法引擎,操作步骤见 (2)。

参考资料:《lex与yacc》机械工业出版社

(1) 下载打包好的包,这种方式的好处是不需用 flex和bison
下载地址:
国际社区
国内镜像 ftp://www.highgo.com.cn/pub/mirrors/pgsql/source/
进入第二步,不需要在 linux 生成任何文件。

(2) clone社区 git 代码库,需要:git flex bison
关于git,它是一个强大到一套糊涂的代码管理工具,请自行了解使用方法,官方网站:
(仍然很不幸,自己想办法)
windows下可以安装 cygwin,选装 git 和 openssh,在 cygwin 环境下使用 git。
官方网站:

需要注意的是,编译开关要一致,以下 a-e 步骤需要在 linux 下执行。
a). 克隆代码库
git clone
b). 配置编译参数,可能需要安装一些开发包,根据错误提示安装即可
./configure --prefix=/usr/local/pg93b1
--enable-nls="zh_cn zh_tw"
--without-perl
--without-python
--without-tcl
--without-gssapi
--without-krb5
--without-pam
--without-ldap
--without-bonjour
--with-openssl
--with-libxml --with-libxslt
--enable-thread-safety
--with-zlib
--without-selinux
c). 编译内核
make
d). 编译外围模组
cd contrib & make
cd ..
e). 编译隔离测试脚本
cd src/test/isolation & make
f). 将如下文件拷贝至 windows 下源代码的相同位置
srcackendootstrapootparse.c
srcackendootstrapootscanner.c
srcackendparsergram.c
srcackendparsergram.h
srcackendparserscan.c
srcackend eplication epl_gram.c
srcackend eplication epl_scanner.c
srcackendutilsmiscguc-file.c
srcinpsqlpsqlscan.c
contribcubecubeparse.c
contribcubecubescan.c
contribsegsegparse.c
contribsegsegscan.c
srcinterfacesecpgpreprocpgc.c
srcinterfacesecpgpreprocpreproc.c
srcinterfacesecpgpreprocpreproc.h
srcplplpgsqlsrcpl_gram.c
srcplplpgsqlsrcpl_gram.h
src estisolationspecparse.c
src estisolationspecscanner.c

2、windows 开发包的下载与准备
windows下编译 postgresql 所需开发包列表见文档 16.1.1. requirements


下载 openssl,这里很全。

ftp://ftp.zlatkovic.com/libxml/
这里也有 openssl,但版本较老。
从这里下载可以下载到 iconv、libxml2、libxslt、zlib,推荐使用


这里下载 gettext

文档提及的 上的包更新已经远远落后于 gnu,但仍然可用。

将下载的包解压到 c:pgbuild 目录

3、微软vc 下载,express版对我们来说足够,还是免费授权。

安装完毕后,建议打好所有补丁。

4、修改 src oolsmsvcconfig_default.pl,指向我们下载到的开发包
nls => "c:\pgbuild\gettext"
openssl => "c:\pgbuild\openssl"
xml => "c:\pgbuild\libxml2"
xslt => "c:\pgbuild\libxslt"
iconv => "c:\pgbuild\iconv"
zlib => "c:\pgbuild\zlib"

6、下载 activeperl 并安装


7、打开 程序菜单 ”microsoft visual studio 2010“ -> ”visual studio tools“ -> ”visual studio command prompt (2010)“
如果是其他版本,注意是 32位的那个,没有把握可以看它的属性,vcvarsall.bat 后边有参数 x86。
set path=%path%;c:pgbuildiconvin;
set path=%path%c:ctiveperl-5.12.xin;
set path=%path%c:pgbuildgettextin;
进入 postgresql 源代码 src oolsmsvc 运行 build.bat
编译完毕后运行: install.bat

8、至此编译完成,但是有些 dll 文件需要手工拷贝,,根据文件缺失错误提示从第二步的开发包目录中查找。

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号