【openGauss】在openEuler(ARM架构)上安装openGauss(一主两备含CM版)

news2024/11/15 9:32:47

一、系统版本介绍

当前案例中的openGauss安装,底层操作系统为openEuler-20.03-LTS版本,当前openGauss对Python版本兼容性最好的是Python 3.6版本与Python 3.7版本,该实验使用的openEuler版本自带Python 3.7.4,不需要再自行安装


二、修改系统配置(主备都需要配置)

1.更改python默认版本(默认是2.x,更改为3.x)

先使用以下命令查看当前系统默认Python版本与系统中的Python3版本,python -V查看的就是默认Python,如果不是3.x版本,需要将默认Python更改为Python3.x的版本

python -V
python3 -V

在这里插入图片描述

执行以下命令将默认Python版本更改为Python3.x版本

mv /usr/bin/python /usr/bin/python.bak
ln -s /usr/bin/python3 /usr/bin/python

在这里插入图片描述

查看当前默认Python版本是否从Python2.x版本切换到了Python3.x版本

2.禁用SELINUX,状态值设置为disabled(重启操作系统生效)

SELINUX全称为Security Enhanced Linux (安全强化 Linux),是对系统安全级别更细粒度的设置。由于SELinux配置设置太严格,可能会与CM需要的功能相冲突。

vi /etc/selinux/config

在这里插入图片描述

3.关闭防火墙

安装过程需要在防火墙关闭情况下完成

systemctl stop firewalld
systemctl disable firewalld

在这里插入图片描述

4.关闭交换内存

关闭交换内存是为了避免数据交换到磁盘 IO 影响性能

swapoff -a

5.修改字符集为utf-8

echo export LANG=en_US.UTF-8 >> /etc/profile

6. 设置时区和时间

使用date命令查看各节点时间是否一致,如果一致就不需要更改,不一致需要配置成一样的
在这里插入图片描述
使用以下命令配置时区与时间

rm -fr /etc/localtime
ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
date -R
hwclock

7.关闭RemoveIPC

默认RemoveIPC=yes,表示当用户退出时,会删除该用户的共享内存段和信号量。

echo RemoveIPC=no >> /etc/systemd/logind.conf
echo RemoveIPC=no >> /usr/lib/systemd/system/systemd-logind.service

重启服务刷新配置(更改完后需要重启服务器,所以可以不重启服务)

systemctl daemon-reload 
systemctl restart systemd-logind

8.注释欢迎语

设置允许root远程登录,openEuler 20.3中默认PermitRootLogin=yes是允许的,所以不需要更改。
修改 Banner 配置,去掉连接到系统,系统提示的欢迎信息。欢迎信息会干扰安装时远程操作的返回结果,影响安装正常执行。

vi /etc/ssh/sshd_config

在这里插入图片描述

重启服务刷新配置(更改完后需要重启服务器,所以可以不重启服务)

systemctl restart sshd.service

9.关闭THP服务

THP(透明大页)功能会降低操作系统的IO性能,而且需要一定的CPU资源对大页碎片进行整理。

echo never >> /sys/kernel/mm/transparent_hugepage/defrag 
echo never >> /sys/kernel/mm/transparent_hugepage/enabled 
echo 'echo never >> /sys/kernel/mm/transparent_hugepage/defrag' >> /etc/rc.d/rc.local 
echo 'echo never >> /sys/kernel/mm/transparent_hugepage/enabled' >> /etc/rc.d/rc.local 
sh /etc/rc.d/rc.local

10.重启操作系统

SELINUX、THP服务的更改需要重启操作系统才生效

reboot

三、配置yum源,下载缺失的依赖包(主备都需要配置)

编辑yum源配置文件

cd /etc/yum.repos.d/
vi openEuler_x86_64.repo

将以下内容添加到repo文件中的末尾

[openEuler]
name=openEuler
baseurl=https://repo.openeuler.org/openEuler-20.03-LTS/everything/x86_64
enabled=1
gpgcheck=1
gpgkey=https://repo.openeuler.org/openEuler-20.03-LTS/everything/x86_64

当前实验源系统环境中不包含expect依赖包,需要自行安装

yum -y install expect --nogpgcheck

–nogpgcheck参数是为了不检查gpg,可以避免源key错误导致的安装失败
在这里插入图片描述


四、准备安装包(只需要在主节点执行)

1.创建安装目录

mkdir -p /opt/software/openGauss

2.解压all、om压缩包
在openGauss社区https://www.opengauss.org/zh/中下载安装包(下载arm架构对应的安装包)
在这里插入图片描述
然后将安装包上传到服务器中,在安装包存储在路径执行以下命令,将安装包解压在/opt/software/openGauss目录下

tar zxf openGauss-3.0.0-openEuler-64bit-all.tar.gz -C /opt/software/openGauss
cd /opt/software/openGauss
tar zxf openGauss-3.0.0-openEuler-64bit-om.tar.gz

3.准备配置文件clusterconfig.xml(/opt/software/openGauss目录下)

vi clusterconfig.xml

1. 注意将nodeNames给为安装数据库的主机名,backIp1s是主机对应的IP
2. dataNode1参数需要将节点2的数据目录也配置上
3. 在每个节点中都需要增加cm的相关配置

<?xml version="1.0" encoding="UTF-8"?> 
<ROOT>
	<!-- openGauss整体信息 --> 
	<CLUSTER> 
		<!-- 数据库名称 --> 
		<PARAM name="clusterName" value="dbCluster" /> 
		<!-- 数据库节点名称(hostname) --> 
		<PARAM name="nodeNames" value="node1,node2,node3" /> 
		<!-- 数据库安装目录--> 
		<PARAM name="gaussdbAppPath" value="/opt/software/install/app" /> 
		<!-- 日志目录--> 
		<PARAM name="gaussdbLogPath" value="/opt/software/log/omm" /> 
		<!-- 临时文件目录--> 
		<PARAM name="tmpMppdbPath" value="/opt/software/tmp" /> 
		<!-- 数据库工具目录--> 
		<PARAM name="gaussdbToolPath" value="/opt/software/om" /> 
		<!-- 数据库core文件目录--> 
		<PARAM name="corePath" value="/opt/software/corefile" /> 
		<!-- 节点IP,与数据库节点名称列表一一对应 --> 
		<PARAM name="backIp1s" value="192.168.0.27,192.168.0.235,192.168.0.246"/> 
	</CLUSTER> 
	<!-- 每台服务器上的节点部署信息 --> 
	<DEVICELIST> 
		<!-- 节点1上的部署信息 --> 
		<DEVICE sn="node1"> 
			<!-- 节点1的主机名称 --> 
			<PARAM name="name" value="node1"/> 
			<!-- 节点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.27"/> 
			<PARAM name="sshIp1" value="192.168.0.27"/> 

			<!--dbnode--> 
			<PARAM name="dataNum" value="1"/> 
			<PARAM name="dataPortBase" value="8000"/> 
			<PARAM name="dataNode1" value="/opt/software/install/data/dn, node2,/opt/software/install/data/dn,node3,/opt/software/install/data/dn"/>
			<PARAM name="dataNode1_syncNum" value="0"/> 
			<!--cm-->
			<PARAM name="cmDir" value="/opt/software/data/cmserver" />
			<PARAM name="cmServerPortBase" value="15000" />
			<PARAM name="cmsNum" value="1" />
			<PARAM name="cmServerlevel" value="1" />
			<PARAM name="cmServerListenIp1" value="192.168.1.112,192.168.1.113,192.168.1.114" />
			<PARAM name="cmServerRelation" value="node1,node2,node3" />
		</DEVICE> 

<!-- 节点2上的节点部署信息,其中“name”的值配置为主机名称 -->
		<DEVICE sn="node2">
			<!-- 节点2的主机名称 -->
			<PARAM name="name" value="node2"/>
			<!-- 节点2所在的AZ及AZ优先级 -->
			<PARAM name="azName" value="AZ1"/>
  			<PARAM name="azPriority" value="1"/>
			<!-- 节点2的IP,如果服务器只有一个网卡可用,将backIp1和sshIp1配置成同一个IP -->
			<PARAM name="backIp1" value="192.168.0.235"/>
			<PARAM name="sshIp1" value="192.168.0.235"/>
			<!-- cm配置 -->
			<PARAM name="cmDir" value="/opt/software/data/cmserver" />
			<PARAM name="cmServerPortBase" value="15000" />
		</DEVICE>
		<!-- 节点3上的节点部署信息,其中“name”的值配置为主机名称 -->
 		<DEVICE sn="node3">
			<!-- 节点3的主机名称 -->
			<PARAM name="name" value="node3"/>
 			<!-- 节点3所在的AZ及AZ优先级 -->
			<PARAM name="azName" value="AZ1"/>
			<PARAM name="azPriority" value="1"/>
  			<!-- 节点3的IP,如果服务器只有一个网卡可用,将backIp1和sshIp1配置成同一个IP -->
 			<PARAM name="backIp1" value="192.168.0.246"/>
 			<PARAM name="sshIp1" value="192.168.0.246"/>
			<!-- cm配置 -->
			<PARAM name="cmDir" value="/opt/software/data/cmserver" />
			<PARAM name="cmServerPortBase" value="15000" />
		</DEVICE>
	</DEVICELIST> 
</ROOT>


五、初始化安装环境gs_preinstall(只需要在主节点执行)

1.更改目录权限

chmod -R 775 /opt/software
chmod -R 777 /opt/software/openGauss

2.初始化安装环境
进入om解压后得到的script目录中

cd /opt/software/openGauss/script
./gs_preinstall -U omm -G dbgrp -X ../clusterconfig.xml

在这里插入图片描述

注意omm用户是不存在的,如果用户存在需要初始化,否则会报错
安装成功如下图所示:
在这里插入图片描述


六、安装gs_install(只需要在主节点执行)

1.更改目录权限

初始化完成后,数据库安装路径权限会被重置为仅root用户可操作,需要重新更改目录权限(主备节点的目录都需要更改权限)

chmod -R 775 /opt/software
chmod -R 777 /opt/software/openGauss

2.切换到系统用户omm,使用omm安装

su omm
cd /opt/software/openGauss/script
./gs_install -X ../clusterconfig.xml

配置登录到数据库的密码(用户就是preinstall -U设置的omm)
在这里插入图片描述

安装成功后如下所示(安装完成后会自动启动服务)
在这里插入图片描述


七、openGauss使用

1.使用OM模块管理集群

(1).启动服务
gs_om -t start

在这里插入图片描述

(2).查看服务状态
gs_om -t status --detail

在这里插入图片描述
关闭状态下查询的结果
在这里插入图片描述

(3).停止服务
gs_om -t stop

在这里插入图片描述

(4).主备切换
gs_ctl switchover -D /opt/software/install/data/dn
gs_ctl failover -D /opt/software/install/data/dn

在这里插入图片描述
查看切换后的状态
在这里插入图片描述

2.使用CM模块管理集群

(1).启动服务
cm_ctl start

在这里插入图片描述

(2).查看服务状态
cm_ctl query -Cv

在这里插入图片描述

关闭状态下查询的结果
在这里插入图片描述

(3).停止服务
cm_ctl stop

在这里插入图片描述

cm_ctl stop -n 1 -D /opt/software/install/data/dn

-n:节点id
-D:实例节点数据目录

(4).主备切换
cm_ctl switchover -n 1 -D /opt/software/install/data/dn
cm_ctl failover -n 1 -D /opt/software/install/data/dn

在这里插入图片描述

查看切换后的状态
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/151181.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

汽车电子系统网络安全活动

声明 本文是学习GB-T 38628-2020 信息安全技术 汽车电子系统网络安全指南. 下载地址 http://github5.com/view/764而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 汽车电子系统网络安全活动 7.1 概念设计阶段 7.1.1 概述 概念设计阶段的活动流程如图…

房产管理系统分布架构分析

一、数图互通房产管理系统采用分布式架构下的高可用设计&#xff1a; &#xff08;1)可以避免因单点故障造成系统平台宕机&#xff1a; a、负载均衡技术&#xff08;failover &#xff0c;选址&#xff0c;硬件负载&#xff0c;软件负载&#xff0c;去中心化负载&#xff08;g…

tp5处理前端上传的图片文件

前端上传了一个图片文件,tp5框架如何处理 效果图&#xff1a; 效果图一: 效果图二: 如果需要看前端如何展示、删除上传的缩略图请到此篇博客&#xff1a; 前端&#xff1a; <form id"upload_pic_wrap" target"upload_file" enctype"multipar…

任务间通讯

信号量与邮箱 系统中的多个任务在运行时&#xff0c;经常需要互相无冲突地访问同一个共享资源&#xff0c;或者需要互相支持和依赖&#xff0c;甚至有时还要互相加以必要的限制和制约&#xff0c;才保证任务的顺利运行。因此&#xff0c;操作系统必须具有对任务的运行进行协调…

C++11引入的尾置返回类型

C11引入的尾置返回类型一、什么是尾置返回类型(trailing return type)二、尾置返回的典型场景2.1 常规方式如何返回数组指针2.2 使用尾置返回类型三、尾置返回类型的应用四、总结一、什么是尾置返回类型(trailing return type) 我们先来看一下传统的函数是怎么定义的&#xff…

Leetcode N皇后

题目链接 Leetcode.51 N 皇后 Leetcode.52 N皇后 II N皇后 题目描述 按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 给你一个…

如何在Vue组件中调用封装好的外部js文件方法

文章目录1、前言2、抽离基本业务js3、在具体组件中调用3.1 引入3.2 组件中调用3.3 实现的效果4、实际项目中的运用4.1 核心展示将一些常用的方法&#xff0c;比如字符串格式化呀&#xff0c;时间格式话呀&#xff0c;常用的表单验证方法呀等等。可以抽离出为基础的业务。在组件…

【Linux】echo命令用法详解

作者&#xff1a;柒号华仔 个人主页&#xff1a;欢迎访问我的主页 个人信条&#xff1a;星光不问赶路人,岁月不负有心人。 个人方向&#xff1a;专注于5G领域&#xff0c;同时兼顾其他网络协议&#xff0c;编解码协议&#xff0c;C/C&#xff0c;linux等&#xff0c;感兴趣的小…

【MySQL】帮助的使用,清晰地解析——?/help命令

MySQL帮助的使用为什么需要‘帮助’命令实际使用? contents 命令显示可供查询的分类子类别内容展示查阅帮助&#xff08;show命令的使用&#xff09;show 命令的用法展示各个表状态信息展示一个表的字段信息为什么需要‘帮助’命令 某个操作的语法忘记了&#xff0c;快速查找…

禅道研发项目管理系统命令注入漏洞(MPS-2023-0418)

漏洞描述 禅道是一款国产开源项目管理软件。 禅道研发项目管理系统存在系统命令注入漏洞&#xff0c;具有后台登陆权限的攻击者可以利用此漏洞执行任意命令&#xff0c;进而控制服务器。 漏洞名称禅道研发项目管理系统命令注入漏洞漏洞类型命令注入发现时间2023/1/6漏洞影响…

分享48个Go源码,总有一款适合您

Go源码 分享48个Go源码&#xff0c;总有一款适合您 Go源码下载链接&#xff1a;https://pan.baidu.com/s/1FhQ6NzB3TWsv9res1OsJaA?pwdr2d3 提取码&#xff1a;r2d3 下面是文件的名字&#xff0c;我放了一些图片&#xff0c;文章里不是所有的图主要是放不下...&#xff0c;…

【安全】RefererXMLHttpRequest部分内容

目录 Referer Referrer-policy 设置referer 盗链 防盗链的工作原理 防盗链的三种方式 如何绕过图片防盗链 XMLHttpRequest 构造函数 XMLHttpRequest 的实例属性 XMLHttpRequest.readyState XMLHttpRequest.onreadystatechange XMLHttpRequest.response XMLHttpRe…

如何从区块链上数据识别出套利行为或者抢跑三明治交易

如何识别链上套利行为或者抢跑夹子三明治行为或交易 识别原子 MEV交易 鉴于交易可以任意复杂并且可以有无数未知交易模式&#xff0c;使用特定交易模式匹配的方法无法应对新的 MEV 模式。为了确定交易中是否发生套利&#xff0c;我们需要对交易进行通用抽象。 以下是我们为认…

【Java寒假打卡】Java基础-集合Set

【Java寒假打卡】Java基础-集合Set概述哈希值hashSet原理HashSet存储学生对象并遍历小结概述 底层数据结构是哈希表不能保证存储和去除的顺序完全一致没有带索引的方法&#xff0c;所以不能使用普通的for循环进行遍历 使用增强for循环或者迭代器进行遍历由于是Set集合&#xf…

PC企业微信4.0 HOOK逆向

最新功能 企业微信已更新到4.0.X版本 &#xff0c;支持控制台的朋友圈、群发等操作。 功能列表: 企业微信接口文档 个人微信已更新至3.7.6.44 个微接口 ***********************分割线***************************** 请求命令码 2000 获取自己的信息 2001 获取指定好友的信息 2…

Reeds-Shepp曲线基础运动公式推导过程

本文是对之前文章“Reeds-Shepp曲线学习笔记及相关思考【点击可跳转】”的补充&#xff0c;因小伙伴的提问&#xff0c;本文补充介绍上述文章第三部分中基础运动公式的推导过程。 本文以上面的第一个公式为例进行介绍&#xff0c;即Reeds-Shepp曲线基础运动中的向前左转运动&am…

JDK 17 史诗级JVM调优

文章目录 JDK 17 之 JVM调优 史诗级 教程 1 调优层次2 调优指标3 JVM调优原则3.1 优先原则3.2 堆设置3.3 年轻代设置3.4 老年代设置3.5 方法区设置3.6 GC设置3.6.1 GC发展阶段3.6.2 G1的适用场景3.6.3 其他收集器适用场景4 JVM调优步骤4.1 监控分析4.1.1 如何生成GC日志4.1.2 …

python + pandas 如何实现web网页的断点连续采集

目录 一、实战场景 二、知识点 python 基础语法 python 文件读写 pandas 数据处理 web 连续采集 三、菜鸟实战 列表页断点连续采集基本思路 基本思路 网页列表页断点连续采集实现 Pandas 保存数据 csv 文件 详情页断点采集思路 基本思路 网页详情页断点连续采集代…

RealWorldCTF2023体验赛 部分WEB

WEB &#x1f411;了拼&#x1f411; 拼图或者直接搜索js文件代码 Evil Mysql Server Mysql恶意服务器读取文件&#xff0c;MySQL_Fake_Server或者Rogue-MySql-Server直接读文件&#xff0c;填写vps的ip端口让服务器连接。 Be-a-Language-Expert 前段时间thinkphp6 多语言…

初级软件测试面试会问什么 拿好这些问题的标准答案,offer不在话下

随着互联网的不断发展&#xff0c;企业对于IT方面的人才需求也越来越大&#xff0c;在追求人才数量的同时&#xff0c;也注重人才质量。而面试就成为把握质量的拦门砖&#xff0c;因此&#xff0c;你想要走心仪的公司&#xff0c;那么你在面试中的表现将会直接决定你求职的成败…