超实用干货(1)-Apache greenplum在aarch64架构体系的适配编译
编译环境
操作系统: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架构体系的适配编译的更多相关文章
- Apache web服务器(LAMP架构)
Apache web服务器(LAMP架构) apache介绍 1).世界上使用率最高的网站服务器,最高时可达70%:官方网站:apache.org 2).http 超文本协议 HTML 超文本标记语言 ...
- Httpd服务进阶知识-基于Apache Modele的LAMP架构之Discuz!案例
Httpd服务进阶知识-基于Apache Modele的LAMP架构之Discuz!论坛案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装依赖包及数据库 博主推荐阅读: ...
- Httpd服务进阶知识-基于Apache Modele的LAMP架构之WordPress案例
Httpd服务进阶知识-基于Apache Modele的LAMP架构之WordPress案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装依赖包及数据库授权 博主推荐阅读 ...
- Httpd服务进阶知识-基于Apache Modele的LAMP架构之PhpMyAdmin案例
Httpd服务进阶知识-基于Apache Modele的LAMP架构之PhpMyAdmin案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.常见LAMP应用 PhpMyAdm ...
- [转帖]X86_64平台上利用qemu安装aarch64架构的虚拟机
X86_64平台上利用qemu安装aarch64架构的虚拟机 https://blog.csdn.net/chenxiangneu/article/details/78955462 遇到原作者一样的问 ...
- 手机CPU架构体系分类及各大厂商
手机cpu相关知识,这对于开发Android应用程序适应各个机型有一定的辅助作用 . 手机cpu架构体系分类 指令集可分为复杂指令集(CISC)和精简指令集(RISC)两部分,代表架构分别是x86.A ...
- 阿里巴巴飞天大数据架构体系与Hadoop生态系统
很多人问阿里的飞天大数据平台.云梯2.MaxCompute.实时计算到底是什么,和自建Hadoop平台有什么区别. 先说Hadoop 什么是Hadoop? Hadoop是一个开源.高可靠.可扩展的分布 ...
- 「译」JUnit 5 系列:架构体系
原文地址:http://blog.codefx.org/design/architecture/junit-5-architecture/ 原文日期:29, Mar, 2016 译文首发:Linesh ...
- WCF技术剖析之二十五: 元数据(Metadata)架构体系全景展现[元数据描述篇]
原文:WCF技术剖析之二十五: 元数据(Metadata)架构体系全景展现[元数据描述篇] 在[WS标准篇]中我花了很大的篇幅介绍了WS-MEX以及与它相关的WS规范:WS-Policy.WS-Tra ...
- 分布式系统的那些事儿(六) - SOA架构体系
有十来天没发文了,实在抱歉!最近忙着录视频,同时也做了个开源的后台管理系统LeeCX,目前比较简单,但是后续会把各类技术完善.具体可以点击“原文链接”. 那么今天继续说分布式系统的那些事. 我们现在动 ...
随机推荐
- CPU性能测试基准(Dhrystone)学习
简介 Dhrystone是测量处理器运算能力的最常见基准程序之一,常用于处理器的整型运算性能的测量.程序是用C语言编写的,因此C编译器的编译效率对测试结果也有很大影响. Dhrystone是由Rein ...
- Android性能优化(一)—— 启动优化,冷启动,热启动,温启动
APP启动方式 App启动方式分三种:冷启动(cold start).热启动(hot start).温启动(warm start) ▲ 冷启动 系统不存在App进程(APP首次启动或APP被完全杀死) ...
- iOS中使用UITextView设置不同文本部分点击事件小结
最近在项目开发中遇到了设置多行文本,点击蓝色邮箱部分跳转到发邮件页面功能.当然比较简单的方式是多标签单独设置,那样稍显麻烦.我们能不能用一个控件,给某一部分添加点击事件,结果是可以的,UITextVi ...
- 03 Transformer 中的多头注意力(Multi-Head Attention)Pytorch代码实现
3:20 来个赞 24:43 弹幕,是否懂了 QKV 相乘(QKV 同源),QK 相乘得到相似度A,AV 相乘得到注意力值 Z 第一步实现一个自注意力机制 自注意力计算 def self_attent ...
- 【ZROJ2730】简单题 可持久化分块题解
Description 给定一棵 \(n\) 个节点的树,每次询问编号为 \([l, r]\) 的点中有多少个是祖先关系. \(n, q \le 10^5\). Solution 直接做的话树上的祖先 ...
- 云原生周刊:Gateway API 1.0.0 发布 | 2023.11.6
开源项目推荐 Kueue Kueue 是一套用于作业队列的 API 和控制器.它是作业级管理器,可决定何时允许作业启动(如创建 pod),何时停止作业(如删除活动 pod). Reloader 一个 ...
- Node.js 构建命令行工具:实现 ls 命令的 -a 和 -l 选项
在日常的前端开发中,我们常常借助各种基于 Node.js 的脚手架工具来加速项目搭建和维护,比如 create-react-app 可以一键初始化一个 React 项目,eslint 则帮助我们保持代 ...
- git reset 之后切换到原来的commit
git reset的语法: git reset [--hard|soft|mixed|merge|keep] [<commit>或HEAD] 作用:将当前分支reset到指定的commit ...
- 命运的X
命运的X cjx 生成函数强. 思路 首先,设 \(f_i\) 为添加第 \(i\) 项后满足条件的概率,\(g_i\) 任意添加至第 \(i\) 项的概率. 我们要求的答案: \[ans=\sum_ ...
- 在哪里可以找到官方的mysql容器图像?
如果您在容器上部署MySQL,那么首要任务之一就是找到正确的镜像. 有一定程度的混乱,尤其是当我们试图帮助部署有问题的人时. 例如,当人们说我使用的是官方的docker镜像- 这到底意味着什么?Doc ...