编译环境

操作系统:EulerOS 2.0 sp8

● 内核:4.19.36

● CPU:aarch64

编译所需软件类别

cmake-3.23.0-rc1.tar.gz

下载地址:

https://cmake.org/files/v3.23/cmake-3.23.0-rc1.tar.gz

gp-xerces-3.1.2-p1.zip

下载地址:

https://github.com/greenplum-db/gp-xer ces/archive/refs/tags/v3.1.2-p1.zip

ninja-1.10.2.zip

下载地址:

https://github.com/ninja-build/ninja/archive /refs/tags/v1.10.2.zip

re2c-3.0.zip

下载地址:

https://github.com/skvadrik/re2c/archive/refs/ta gs/3.0.zip

zstd-1.5.2.tar.gz

下载地址:

https://github.com/facebook/zstd/releases/download/v1.5.2/zstd-1.5.2.tar.gz

配置yum源,并安装如下依赖包

autoconf

automake

libtool

gcc

curl-devel

bzip2-devel

python-devel

openssl-devel

readline-devel

perl-ExtUtils-Embed

libxml2-devel

openldap-devel

pam

pam-devel

apr-devel

libevent-devel

libyaml

libyaml-devel

libedit-devel

libffi-devel

bison

flex

flex-devel

安装python依赖包

# 使⽤pip 进⾏python包管理,命令如下:

pip install --upgrade pip

pip install --no-cache-dir lockfile paramiko setuptools psutil conan

逐个安装软件列表内容

可以根据每个软件的readme⽂件进⾏安装

编译

编译GreenPlum 需要cmake和gcc,在上⾯操作中已经配置完成,开始前可通过如下命令进⾏确认

检查gcc版本

[root@RI_BDTL ~]# gcc --version

gcc (GCC) 7.3.0

检查cmake版本

[root@RI_BDTL ~]# cmake --version

cmake version 3.23.0-rc1

准备源码包

6.19.1-src-full.tar.gz

下载地址:

https://github.com/greenplum-db/gpdb/releases/download/6.19.1/ 6.19.1-src-full.tar.gz

修改源码 (6.19.1源码中没有对平台判断,修改为aarch64⽀持的指令)

[root@RI_BDTL packages]# tar -zxvf 6.19.1-src-full.tar.gz

[root@RI_BDTL packages]# vi gpdb_src/src/backend/gporca/libgpos/includ e/gpos/utils.h

修改 gpdb_src/src/backend/gporca/libgpos/include/gpos/utils.h 中22⾏和23⾏为:

#define GPOS_ASMFP asm volatile("mov %0, fp" : "=g"(ulp));

#define GPOS_ASMSP asm volatile("mov %0, sp" : "=g"(ulp));

编译,编译命令使⽤的readme中的命令,默认是带orca编译的,这⾥通过 --enable-orca 显示指定了

[root@RI_BDTL packages]# cd gpdb_src

# Configure build environment to install at /usr/local/greenplum-6.19.1

[root@RI_BDTL gpdb_src]# export LD_LIBRARY_PATH=/usr/local/gp-xerces/l ib/ CFLAGS="-I/usr/local/gp-xerces/include" LDFLAGS="-L/usr/local/gp-x erces/lib/"

[root@RI_BDTL gpdb_src]# ./configure --enable-orca --with-perl --withpython --with-libxml --with-gssapi --prefix=/usr/local/greenplum-6.19.1

[root@RI_BDTL gpdb_src]# make -j8

[root@RI_BDTL gpdb_src]# make -j8 install

漫⻓的等待之后,出现如下提示,就说明编译成功了

Greenplum Database installation complete

查看编译结果

[root@RI_BDTL local]# ls -lrt greenplum-6.19.1/

总⽤量 32

drwx------ 3 gpadmin gpadmin 4096 2⽉ 11 15:47 docs

drwx------ 4 gpadmin gpadmin 4096 2⽉ 11 16:11 share

drwx------ 4 gpadmin gpadmin 4096 2⽉ 11 16:14 include

drwx------ 5 gpadmin gpadmin 4096 2⽉ 11 16:14 lib

-rw------- 1 gpadmin gpadmin 491 2⽉ 11 16:14 greenplum_path.sh

drwx------ 2 gpadmin gpadmin 4096 2⽉ 11 16:14 libexec

drwx------ 2 gpadmin gpadmin 4096 2⽉ 11 16:14 sbin

drwx------ 7 gpadmin gpadmin 4096 2⽉ 11 16:14 bin

总结

编译过程并不复杂,难点在于有⼀些依赖包安装的不全,导致编译不成功。

另外就是源码包6.19.1中对aarch64指令集的修改,使GreenPlum可以正常编译。

超实用干货(1)-Apache greenplum在aarch64架构体系的适配编译的更多相关文章

  1. Apache web服务器(LAMP架构)

    Apache web服务器(LAMP架构) apache介绍 1).世界上使用率最高的网站服务器,最高时可达70%:官方网站:apache.org 2).http 超文本协议 HTML 超文本标记语言 ...

  2. Httpd服务进阶知识-基于Apache Modele的LAMP架构之Discuz!案例

    Httpd服务进阶知识-基于Apache Modele的LAMP架构之Discuz!论坛案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装依赖包及数据库  博主推荐阅读: ...

  3. Httpd服务进阶知识-基于Apache Modele的LAMP架构之WordPress案例

    Httpd服务进阶知识-基于Apache Modele的LAMP架构之WordPress案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装依赖包及数据库授权 博主推荐阅读 ...

  4. Httpd服务进阶知识-基于Apache Modele的LAMP架构之PhpMyAdmin案例

    Httpd服务进阶知识-基于Apache Modele的LAMP架构之PhpMyAdmin案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.常见LAMP应用 PhpMyAdm ...

  5. [转帖]X86_64平台上利用qemu安装aarch64架构的虚拟机

    X86_64平台上利用qemu安装aarch64架构的虚拟机 https://blog.csdn.net/chenxiangneu/article/details/78955462 遇到原作者一样的问 ...

  6. 手机CPU架构体系分类及各大厂商

    手机cpu相关知识,这对于开发Android应用程序适应各个机型有一定的辅助作用 . 手机cpu架构体系分类 指令集可分为复杂指令集(CISC)和精简指令集(RISC)两部分,代表架构分别是x86.A ...

  7. 阿里巴巴飞天大数据架构体系与Hadoop生态系统

    很多人问阿里的飞天大数据平台.云梯2.MaxCompute.实时计算到底是什么,和自建Hadoop平台有什么区别. 先说Hadoop 什么是Hadoop? Hadoop是一个开源.高可靠.可扩展的分布 ...

  8. 「译」JUnit 5 系列:架构体系

    原文地址:http://blog.codefx.org/design/architecture/junit-5-architecture/ 原文日期:29, Mar, 2016 译文首发:Linesh ...

  9. WCF技术剖析之二十五: 元数据(Metadata)架构体系全景展现[元数据描述篇]

    原文:WCF技术剖析之二十五: 元数据(Metadata)架构体系全景展现[元数据描述篇] 在[WS标准篇]中我花了很大的篇幅介绍了WS-MEX以及与它相关的WS规范:WS-Policy.WS-Tra ...

  10. 分布式系统的那些事儿(六) - SOA架构体系

    有十来天没发文了,实在抱歉!最近忙着录视频,同时也做了个开源的后台管理系统LeeCX,目前比较简单,但是后续会把各类技术完善.具体可以点击“原文链接”. 那么今天继续说分布式系统的那些事. 我们现在动 ...

随机推荐

  1. docker 安装 elasticsearch 集群

    此处部署为单个服务器启动三个elasticsearch容器 问题:本打算在三个服务器上单独部署elasticsearch 容器,elasticsearch.yml 注册用的宿主机ip,但是容器之间通信 ...

  2. CTF中特别小的EXE是怎么生成的

    我们在打CTF时候,出题的爷爷们给出的exe都很小 就10k左右,有的甚至就5k,那时候我很郁闷啊.现在我也能了啊哈哈 不多bb按如下操作: 我们来看看正常的release生成的代码 #include ...

  3. 2024年5月中国数据库排行榜:OP持续领跑,GoldenDB稳步上升进前八

    入夏时节,2024年5月的中国流行度排行榜排行榜如期发布.在这个骄阳似火的季节,各大数据库产品之间的竞争愈发激烈,名次间的细微变动展示了市场的动态和活力.各家厂商不断创新,通过技术升级和性能优化,力求 ...

  4. 2022年最新数据库经典面试题及答案汇总(含PostgreSQL、Oracle、MySQL)

    随着企业数字化需求的增加,数据库行业发展日益壮大,企业对DBA岗位的需求也处于逐步增加中.我们梳理了墨天轮平台上2022年最新的一批数据库经典面试题,主要包含PostgreSQL.MySQL和Orac ...

  5. vue前端开发仿钉图系列(1)高德地图的使用详解

    最近公司让参考钉图做图层模块相关的功能,很庆幸有机会细细研究地图相关的东西.因为手机端用的是高德地图,web端也使用高德地图.还是和往常一样,先贴上效果图. 步骤1.在高德开放平台注册信息,创建自己的 ...

  6. js自动调用 click 事件

    // 进入页面立即触发 (()=>{ // 兼容IE if(document.all) { document.getElementById("aid").click(); } ...

  7. .NET 开源餐饮系统支持桌面与Web版

    前言 推荐一款优秀的开源免费餐饮系统-蜀味正道,专门针对餐饮行业开发的桌面应用程序,帮助大家提供全面的管理解决方案. 项目介绍 蜀味正道是一款借助 Panuon.UI.Silver控件库开发的餐饮软件 ...

  8. 安装gd库出错

    最近手痒,就安装了一个centos 6.5玩玩. 由于新的centos的当前版本已经达到7.1. 而且最糟的是在本人不小心的时候在安装软件的时候, 确定里里面的更新系统命令,导致版本变为了6.9. 然 ...

  9. Games101 作业8 质点弹簧系统

    目录 1 前言 2 基础数据结构 3 欧拉 4 Verlet Integration 4.1 Constraints 1 前言 质点弹簧系统的模拟仿真,其实非常简单,核心就是牛顿第二定律 \(F = ...

  10. Centos7安装部署prometheus

    普罗米修斯的主要特点是: 具有由度量名称和键/值对标识的时间序列数据的多维数据模型 PromQL,一种灵活的查询语言, 可以利用这一维度 不依赖分布式存储; 单个服务器节点是自治的 时间序列集合通过H ...