当前位置: 首页 > news >正文

Centos服务器Open Gauss 部署

近期很多的项目由于信创要求使用一些国产的数据库,比如OpenGauss。OpenGuass是华为高斯DB的开源版,内核还是PostgreSQL,商业版是收费的。这里记录一下是如何安装部署 的。

官方中文文档
官方下载地址

部署要求

  1. 操作系统要求
  • ARM:
    • openEuler 20.3LTS
    • 麒麟V10
    • Asianux 7.5
  • X86:
    • openEuler 20.3LTS
    • CentOS 7.6
    • Asianux 7.6

我使用的使用是Centos7.4

操作系统环境依赖安装

  1. 一般以来
yum repolist
yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make libffi-devel bzip2  
  1. python3环境部署

OpenGauss的部署依赖于Python3的环境,我使用的Python3.6.10。下载地址

mkdir -p /opt/python3   	#(将python-3.6.10.tgz放入)
python -V				#查看当前python版本,centos默认为2.7版本
cd /opt/python3
tar xf Python-3.6.10.tgz					#解压软件包
cd  Python-3.6.10								#进入文件目录
./configure --prefix=/usr/local/python3 --enable-shared CFLAGS=-fPIC						#若报错就是没有安装gcc,yum install gcc(yum源配置里我加了gcc了)
make 
make install								#(进行python3的安装)
cd /usr/local				
ll						#(该目录下出现python3即安装完毕)
unlink /usr/bin/pythonln -s /usr/local/python3/bin/python3.6 /usr/bin/python   #(创建软连接)
ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3
ln -s /usr/local/python3/bin/pip3.6 /usr/bin/pip
cp /usr/local/python3/lib/libpython3.6m.so.1.0 /usr/lib64
python -V  		#(此时python版本变为3.6)
yum repolist
#(更改了默认python版本的话,yum命令就用不了,因为yum文件是按照老版本的python2.7编译执行的,所以要将yum文件里面的第一行注释给定义到老版本的python2
vi /usr/bin/yum
#修改第一行python为python2
#此时yum恢复
yum repolist

创建文件夹

注意需要创建两个文件夹,一个用于放置部署文件,另一个空置

mkdir/home/openGauss   # 用于自动化部署到此位置
mkdir /home/open       # 后续安装文件解压到此目录,xml上传至此目录

创建用户组

创建OpenGauss默认的用户组,并给与这两个文件夹的权限

sudo groupadd dbgrp
sudo chgrp  -R  dbgrp  /home/openGauss
sudo chgrp  -R  dbgrp  /home/open

下载安装包

官方下载地址

注意只支持x86_64架构Centos系统

下载安装包

解压安装包

tar xvf /home/openGauss/openGauss-5.0.1-CentOS-64bit-all.tar.gz -C /home/open
cd /home/open
tar xvf openGauss-5.0.1-CentOS-64bit-om.tar.gz # 解压脚本工具

配置xml文件

配置之前,需要将服务器名称改了与xml中的一致。

hostnamectl set-hostname opengauss1

高斯数据库的部署,主要依赖与xml配置文件。我是参考官网文档配置的单实例,多实例的官网也有说明,注意替换自己的ip与服务器名称。

<?xml version="1.0" encoding="UTF-8"?>
<ROOT><!-- openGauss整体信息 --><CLUSTER><!-- 数据库名称 --><PARAM name="clusterName" value="dbCluster" /><!-- 数据库节点名称(hostname) --><PARAM name="nodeNames" value="opengauss1" /><!-- 数据库安装目录--><PARAM name="gaussdbAppPath" value="/home/openGaussGauss/app" /><!-- 日志目录--><PARAM name="gaussdbLogPath" value="/home/openGaussGauss/log" /><!-- 临时文件目录--><PARAM name="tmpMppdbPath" value="/home/openGauss/tmp" /><!-- 数据库工具目录--><PARAM name="gaussdbToolPath" value="/home/openGauss/om" /><!-- 数据库core文件目录--><PARAM name="corePath" value="/home/openGauss/corefile" /><!-- 节点IP,与数据库节点名称列表一一对应 --><PARAM name="backIp1s" value="192.168.0.14"/> </CLUSTER><!-- 每台服务器上的节点部署信息 --><DEVICELIST><!-- 节点1上的部署信息 --><DEVICE sn="node1_hostname"><!-- 节点1的主机名称 --><PARAM name="name" value="opengauss1"/><!-- 节点1所在的AZ及AZ优先级 --><PARAM name="azName" value="AZ1"/><PARAM name="azPriority" value="1"/><!-- 节点1的IP,如果服务器只有一个网卡可用,将backIP1和sshIP1配置成同一个IP --><PARAM name="backIp1" value="192.168.0.14"/><PARAM name="sshIp1" value="192.168.0.14"/><!--dbnode--><PARAM name="dataNum" value="1"/><PARAM name="dataPortBase" value="15400"/><PARAM name="dataNode1" value="/home/openGauss/data/dn"/><PARAM name="dataNode1_syncNum" value="0"/></DEVICE></DEVICELIST>
</ROOT>

将xml保存为clusterconfig.xml,并上传至/home/open

执行预安装

cd /home/open/script/
./gs_preinstall -U omm -G dbgrp -X /home/open/clusterconfig.xml

注意安装过程中,会提示创建omm用户,让设置用户的密码。

一般都是会报python、或者文件权限的错误
预安装

正式安装

预安装成功后,最好再给一遍权限

chmod -R 775 /home/open
chmod -R 777 /home/openGauss

切换到omm用户,正式安装,安装过程中,会让设置一个长度不低于8位的密码

su omm
cd /home/open/script
./gs_install -X ../clusterconfig.xml
gs_om -t start # 启动数据库
gs_om -t status # 查看数据库状态
gs_om -t status  --detail # 查看详细数据库状态
gs_om -t stop # 关闭数据库

安装成功

最后查看安装文件,发现里面很多还都是postgresql的原文件

相关文章:

  • Python练习
  • k8s安装traefik作为ingress
  • 科技下乡:数字乡村改变乡村生活方式
  • 物联网实战--入门篇之(三)嵌入式STM32
  • 如何应对复杂软件工程的开发流程?
  • JVM(二)——垃圾回收
  • 新网站收录时间是多久,新建网站多久被百度收录
  • 沃尔玛百货有限公司 企业网页设计制作 企业html网页成品 跨国公司网页设计开发 web前端开发,html+css网页设计素材,静态html学生网页成品源码
  • BIM自动化简介
  • 主流公链 - Monero
  • 2024年github开源top100中文
  • AI时代Python金融大数据分析实战:ChatGPT让金融大数据分析插上翅膀
  • 【数据分享】1929-2023年全球站点的逐月平均海平面压力(Shp\Excel\免费获取)
  • C# 打印输出以及文件输入输出
  • 在VMware Workstations 中安装windows7并安装vmware tools(解决升级到SP1和VMCI无法安装问题)
  • 【译】理解JavaScript:new 关键字
  • ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较
  • ComponentOne 2017 V2版本正式发布
  • express + mock 让前后台并行开发
  • JavaWeb(学习笔记二)
  • js数组之filter
  • LeetCode刷题——29. Divide Two Integers(Part 1靠自己)
  • Linux编程学习笔记 | Linux IO学习[1] - 文件IO
  • mysql innodb 索引使用指南
  • opencv python Meanshift 和 Camshift
  • passportjs 源码分析
  • SpingCloudBus整合RabbitMQ
  • vue-loader 源码解析系列之 selector
  • windows-nginx-https-本地配置
  • 理解在java “”i=i++;”所发生的事情
  • 世界上最简单的无等待算法(getAndIncrement)
  • 探索 JS 中的模块化
  • 一个项目push到多个远程Git仓库
  • 原生 js 实现移动端 Touch 滑动反弹
  • Java数据解析之JSON
  • mysql 慢查询分析工具:pt-query-digest 在mac 上的安装使用 ...
  • Spring第一个helloWorld
  • ​ssh免密码登录设置及问题总结
  • ​渐进式Web应用PWA的未来
  • #13 yum、编译安装与sed命令的使用
  • (1)(1.9) MSP (version 4.2)
  • (2)(2.10) LTM telemetry
  • (9)YOLO-Pose:使用对象关键点相似性损失增强多人姿态估计的增强版YOLO
  • (TipsTricks)用客户端模板精简JavaScript代码
  • (非本人原创)我们工作到底是为了什么?​——HP大中华区总裁孙振耀退休感言(r4笔记第60天)...
  • (附源码)计算机毕业设计ssm本地美食推荐平台
  • (未解决)jmeter报错之“请在微信客户端打开链接”
  • (五)c52学习之旅-静态数码管
  • **PHP分步表单提交思路(分页表单提交)
  • .NET C# 使用 SetWindowsHookEx 监听鼠标或键盘消息以及此方法的坑
  • .net core webapi 部署iis_一键部署VS插件:让.NET开发者更幸福
  • .NET Core 将实体类转换为 SQL(ORM 映射)
  • .NET Core 项目指定SDK版本
  • .net利用SQLBulkCopy进行数据库之间的大批量数据传递
  • .net专家(张羿专栏)