用icc编译Postgresql

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介: 试着换个编译器编译下Postgresql的源码,比想象的要简单的多。 然后又跑了下TPC-H

试着换个编译器编译下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的结果我还没有分析,要花时间多研究下。


--以上


相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
10天前
|
Docker 容器 关系型数据库
【PolarDB-X从入门到精通】 第四讲:PolarDB分布式版安装部署(源码编译部署)
本期课程将于4月11日19:00开始直播,内容包括源码编译基础知识和实践操作,课程目标是使学员掌握源码编译部署技能,为未来发展奠定基础,期待大家在课程中取得丰富的学习成果!
【PolarDB-X从入门到精通】 第四讲:PolarDB分布式版安装部署(源码编译部署)
|
4月前
|
SQL 关系型数据库 C语言
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
45 0
|
4月前
|
SQL 关系型数据库 数据库
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
47 0
|
11月前
|
SQL 缓存 关系型数据库
【PostgreSQL 架构】PostgreSQL 11和即时编译查询
【PostgreSQL 架构】PostgreSQL 11和即时编译查询
|
关系型数据库 Linux PostgreSQL
LINUX下载编译libpq(postgresql)
LINUX下载编译libpq(postgresql)
385 0
|
网络协议 关系型数据库 MySQL
Centos7 源码编译安装 PostgreSQL11.5
Centos7 源码编译安装 PostgreSQL11.5
418 0
Centos7 源码编译安装 PostgreSQL11.5
|
关系型数据库 Linux PostgreSQL
|
关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 IV. 客户端接口_第 33 章 libpq - C 库_33.20. 编译 libpq 程序
33.20. 编译 libpq 程序 要编译(即编译并且链接)一个使用libpq的程序,你需要做下列所有的事情: 包括libpq-fe.h头文件: #include <libpq-fe.h> 如果你无法这样做,那么你通常会从你的编译器得到像这样的错误消息: foo.
1387 0
|
9月前
|
SQL Cloud Native 关系型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
730 1