[转载]用intel编译器icc编译PostgreSQL
背景
原文
https://yq.aliyun.com/articles/52304
正文
试着换个编译器编译下Postgresql的源码,比想象的要简单的多。
1. 下载9.6的源码
从PG的git仓库下直接down下来
http://git.postgresql.org/gitweb/?p=postgresql.git;a=summary
2. 先用gcc的方式编译
详见
# ./configure
问题1) readline library not found
遇到了类似于 readline library not found 这样几个问题
其实并不是缺少readline,而是缺devel版本。我是在centos上做的,所以用yum安装了下。
除了readline,还有zlib,bison, Flex,都是通过安装devel版本解决了。
# make
# make install
一路畅通
3. 换用icc的方式
先要下载icc。
https://software.intel.com/en-us/articles/using-intel-compilers-for-linux-under-redhat-enterprise-linux
icc是intel的编译器,是包含在他们的开发软件里面的。
intel的开发软件不是免费的,但是可以申请学生版,要用edu邮箱申请。
安装的时候,要customize下,只安装icc组件。如果整个软件安装的话,要7G空间。
# ./configure CC=/opt/intel/bin/icc
竟然没有错误的编译完了
# make
# make install
一路畅通
只不过在initdb的时候,会有libintlc.so这个库找不到,是因为这是intel的icc里面的。在LD_LIBRARY_PATH变量里加上icc的lib目录。
之后使用正常。
4. 跑一下tpc-h
先从官网down下来tpc的代码。
因为tpch里面没有直接支持Postgresql,所以语法上要小改一下。
github上有自动化的脚本,我就拿来用了。
https://github.com/tvondra/pg_tpch
https://github.com/digoal/pg_tpch
TPCH的结果我还没有分析,要花时间多研究下。
5. 更多ICC编译器的优化选项,参考ICC手册。