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

在ARM架构服务器上编译Greenplum6并制作rpm安装包

刘雪柏

诺基亚东软通信有限公司 高级软件工程师
从事数据库相关工作 aiden.liu@qq.com

Greenplum 是一款开源MPP数据分析平台,提供包括数据分析、机器学习和人工智能等特色功能。目前 Greenplum 的二进制发行版本只能运行在 X86 服务器。github上的Greenplum releases只有x86的发行版,没有提供ARM 发行版。Greenplum 是开源软件,我们可以通过编译 Greenplum 源代码自行构建 Greenplum 的 ARM 版本。

本文将详细讲述如何在 ARM 服务器上编译并打包开源版 Greenplum。

编译环境:CentOS Linux release 7.6.1810 (AltArch)

需要提前准备OS镜像、python依赖包、cmake、zstd-dev、Xerces、re2c、ninja、gporca等源码包配置编译环境,另外Greenplum编译需要Greenplum源码包。

下载并上传如下软件包到服务器上:

bcrypt-3.1.7.tar.gz

cffi-1.14.1.tar.gz

cryptography-3.0.tar.gz

enum34-1.1.10.tar.gz

epydoc-3.0.1.zip

gporca-3.106.1.tar.gz

gp-xerces-3.1.2-p1.tar.gz

greenplum-6.9.1-src-full.tar.gz

ipaddress-1.0.23.tar.gz

lockfile-0.12.2.tar.gz

ninja-1.10.0.tar.gz

paramiko-2.7.1.tar.gz

pbr-5.4.5.tar.gz

psutil-5.7.2.tar.gz

pycparser-2.20.tar.gz

PyNaCl-1.4.0.tar.gz

re2c-2.0.tar.gz

setuptools-33.1.1.zip

six-1.15.0.tar.gz

zstd-1.4.5.tar.gz

安装依赖包:

#yum -y install curl-devel bzip2-devel python-devel openssl-devel readline-devel perl-ExtUtils-Embed libxml2-devel openldap-devel pam pam-devel perl-devel apr-devel libevent-devel libyaml libyaml-devel libedit-devel libffi-devel

安装python依赖包:

安装setuptools

# cd setuptools-master

# python bootstrap.py

# python setup.py install

安装psutil

# cd psutil-5.7.2

# python setup.py install

安装pbr

# cd pbr-5.4.5

# python setup.py install

安装lockfile

# cd lockfile-0.12.2

# python setup.py install

安装pycparser

# cd pycparser-2.20

# python setup.py install

安装cffi

# cd cffi-1.14.1

# python setup.py install

安装six

# cd six-1.15.0

# python setup.py install

安装bcrypt

# cd bcrypt-3.1.7

# python setup.py install

安装PyNaCl

# cd PyNaCl-1.4.0

# python setup.py install

安装ipaddress

# cd ipaddress-1.0.23

# python setup.py install

安装enum34

# cd enum34-1.1.10

# python setup.py install

安装cryptography

# cd cryptography-3.0

# python setup.py install

安装paramiko

# cd paramiko-2.7.1

# python setup.py install

安装epydoc

# cd epydoc-3.0.1

# python setup.py install

安装cmake

# cd cmake-3.9.2

# ./bootstrap

# make

# make install

# usr/local/bin/cmake --version

安装zstd

# cd zstd-1.4.5

# make

# make install

安装Xerces

# cd gp-xerces-3.1.2-p1

# ./configure

# make

# make install

安装re2c

# cd re2c-2.0

# ./autogen.sh

# ./configure

# make

# make install

安装ninja

# cd ninja-1.10.0

# ./configure.py --bootstrap

# cp ninja usr/bin/

安装gporca

# cd gporca-3.106.1

# cmake -GNinja -H. -Bbuild

# vi libgpos/src/common/CStackDescriptor.cpp

第167行注释掉

# ninja install -C build

# echo /usr/local/lib >/etc/ld.so.conf

# ldconfig

编译greenplum6.9.1

准备完成后可以编译greenplum6.9.1了

# cd gpdb_src/

# ./configure --with-perl --with-python --with-libxml --prefix=/usr/local/gpdb

#make

如果make成功了,就可以开始制作rpm安装包了。

安装rpm-build

yum install rpm-build

在/root目录下建rpmbuild目录

mkdir-p~/rpmbuild/BUILD~/rpmbuild/RPMS~/rpmbuild/BUILDROOT ~/rpmbuild/SRPMS ~/rpmbuild/SOURCES ~/rpmbuild/SPECS

编辑greenplum6.9.1.spec

vi ~/rpmbuild/SPECS/greenplum6.9.1.spec

修改greenplum源代码目录名为greenplum-6.9.1并压缩:

mv gpdb_src greenplum-6.9.1

tar czvf greenplum-6.9.1.tar.gz greenplum-6.9.1

把greenplum源码包复制到rpmbuild源代码目录

cp greenplum-6.9.1.tar.gz ~/rpmbuild/SOURCES/

制作rpm安装包:

rpmbuild -ba ~/rpmbuild/SPECS/greenplum6.9.1.spec

查看制作好的rpm安装包:

完。



I Love PG

关于我们

PostgreSQLPG2017PostgreSQLPG非盈利行业协会组织。我们致力于在中国PostgreSQLPostgreSQL


欢迎投稿

做你的舞台,show出自己的才华 。

投稿邮箱:partner@postgresqlchina.com

                    

                    ——愿能安放你不羁的灵魂


技术文章精彩回顾




PostgreSQL学习的九层宝塔
PostgreSQL职业发展与学习攻略
2019,年度数据库舍 PostgreSQL 其谁?
Postgres是最好的开源软件
PostgreSQL是世界上最好的数据库
从Oracle迁移到PostgreSQL的十大理由
从“非主流”到“潮流”,开源早已值得拥有

PG活动精彩回顾




创建PG全球生态!PostgresConf.CN2019大会盛大召开
首站起航!2019“让PG‘象’前行”上海站成功举行
走进蓉城丨2019“让PG‘象’前行”成都站成功举行
中国PG象牙塔计划发布,首批合作高校授牌仪式在天津举行
群英论道聚北京,共话PostgreSQL
相聚巴厘岛| PG Conf.Asia 2019  DAY0、DAY1简报
相知巴厘岛| PG Conf.Asia 2019 DAY2简报
独家|硅谷Postgres大会简报
直播回顾 | Bruce Momjian:原生分布式将在PG 14版本发布

PG培训认证精彩回顾




中国首批PGCA认证考试圆满结束,203位考生成功获得认证!
中国第二批PGCA认证考试圆满结束,115位考生喜获认证!
重要通知:三方共建,中国PostgreSQL认证权威升级!
近500人参与!首次PGCE中级、第三批次PGCA初级认证考试落幕!
2020年首批 | 中国PostgreSQL初级认证考试圆满结束
一分耕耘一分收获,第五批次PostgreSQL认证考试成绩公布
PG专辑预览阅读




开源软件联盟PostgreSQL分会专辑之活动篇


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

评论