暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

[转载]用intel编译器icc编译PostgreSQL

digoal 2016-05-24
804

作者

digoal

日期

2016-05-24

标签

PostgreSQL , PostGIS , 栅格 , raster , 多核并行


背景

原文

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的方式编译

详见

《PostgreSQL on Linux 最佳部署手册》

```

./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手册。

PostgreSQL 许愿链接

您的愿望将传达给PG kernel hacker、数据库厂商等, 帮助提高数据库产品质量和功能, 说不定下一个PG版本就有您提出的功能点. 针对非常好的提议,奖励限量版PG文化衫、纪念品、贴纸、PG热门书籍等,奖品丰富,快来许愿。开不开森.

9.9元购买3个月阿里云RDS PostgreSQL实例

PostgreSQL 解决方案集合

德哥 / digoal's github - 公益是一辈子的事.

digoal's wechat

文章转载自digoal,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论