华为GAUSS数据库的安装和部署(基于centos 7.6的版本)- 企业版单节点安装

可能会用到的相关gauss数据库安装软件包:

https://pan.baidu.com/s/1l6mza570Ze2VmYkrn-_SZQ 
提取码:92z7

一、 前期准备

1. 有一些后面需要用到的安装包,需要先部署

yum -y install gcc net-tools wget openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel libaio-devel flex bison ncurses-devel glibc-devel patch redhat-lsb-core libnsl vim lrzsz bzip2

2. gauss数据库依赖python3.6的环境,这里安装一个

下载3.6.5的版本

wget https://www.python.org/ftp/python/3.6.5/Python-3.6.5.tgz

解压配置和安装python版本

tar -zxvf Python-3.6.5.tgz

cd Python-3.6.5

mkdir /usr/local/python3

./configure --prefix=/usr/local/python3 --enable-shared --with-ssl

make && make install

cp /usr/local/python3/lib/libpython3.6m.so.1.0 /usr/lib64/

建立python3的系统软链接

ln -s /usr/local/python3/bin/python3 /usr/bin/python3

ln -s /usr/local/python3/bin/pip3 /usr/bin/pip3

输入python3可以进行验证

3. linux的sem值修改

先修改系统的semni数值,默认的值是128,华为的高斯数据库需要的最大信号量数值更高,这里我改成了2048,。

vim /etc/sysctl.conf

通过 sysctl -p 来查看修改之后的值

4. openssl版本修改

华为高斯数据库的openssl要求版本是1.1以上,我的centos默认是1.0.2的版本,这个也需要升级。

先在官网上下载一个1.1版本的压缩包

wget https://www.openssl.org/source/openssl-1.1.1g.tar.gz --no-check-certificate

解压压缩包并且对它进行配置、编译和安装

tar -xvf openssl-1.1.1g.tar.gz

cd openssl-1.1.1g

./config shared --openssldir=/usr/local/openssl --prefix=/usr/local/openssl

make && make install

更新系统中原有的版本,替换系统openssl的软链接

mv /usr/bin/openssl /usr/bin/openssl.old

ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl

ln -s /usr/local/openssl/include/openssl /usr/include/openssl

echo "/usr/local/openssl/lib" >> /etc/ld.so.conf

ldconfig -v

最后可以验证是否成功

openssl version

a921d90b9fa576c82da62c7dbf21867e.png 

二、进行华为GAUSS数据库企业版的安装(单节点服务器)

1. 创建/opt/software/openGauss文件夹

mkdir -p /opt/software/openGauss

2. 将企业版的安装包上传到该目录,并且进行解压

因为我一开始是把安装包上传到了/home目录,所以我先做了一次mv的剪切操作:

mv /home/openGauss-3.0.0-CentOS-64bit-all.tar.gz /opt/software/openGauss/

cd /opt/software/openGauss/

tar -zxvf openGauss-3.0.0-CentOS-64bit-all.tar.gz

tar -zxvf openGauss-3.0.0-CentOS-64bit-om.tar.gz

3. 修改服务器的主机名

hostnamectl set-hostname master

4. 关闭和删除服务器的防火墙设置

service firewalld stop

chkconfig firewalld off

5. 修改/etc/selinux/config文件,修改SELINUX的值,将值改成disabled

SELINUX=disabled

修改完成后重启服务器。

reboot

6. 修改服务器的时区信息

cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

7. 关闭服务器的交换内存

swapoff -a

8. 设置网卡的mtu值为1500

ifconfig ens33 mtu 1500

9. 设置root用户远程登录

修改ssd_config文件:将里面的PermitRootLogin选项改成 yes,找到这一行,去掉PermitRootLogin前面的 # 注释就行了

vim /etc/ssh/sshd_config

b9417a4dd85e28add43239a172e6bc36.png 

service sshd restart

10. 以root用户重新登录

ssh 192.168.2.203

11. 复制服务器的xml配置文件

cp /opt/software/openGauss/script/gspylib/etc/conf/cluster_config_template.xml /opt/software/openGauss/cluster_config.xml

12. 修改 /opt/software/openGauss/cluster_config.xml 文件

将文件内容全部删除掉,将以下的内容粘贴到自己的 cluster_config.xml文件中,并且对主机名和ip地址进行替换,然后保存文件

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

13. 使用 gs_preinstall 进行交互模式执行安装环境

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

这里的omm是准备数据库使用的系统用户,dbgrp是这个用户所在的用户组。

14. 给 omm 用户赋予 opt 文件夹的权限

chmod -R 775 /opt

15. 创建脚本互信文件,在hostfile文件中写入自己的ip地址

cd /opt/software/openGauss/

vim hostfile

16. 切换到 omm 用户,开始安装 gauss 数据库

su - omm

17. 安装 gauss 数据库

gs_install -X /opt/software/openGauss/cluster_config.xml

在安装过程中需要输入数据库密码,密码要由符号、大小写英文组成,至少长度达到8位,例如Test@123

18. 进行数据库安装之后的校验

gs_om -t status --detail

 693cca24e0f5841324a78a2739604493.png

19. 数据库的启动

gs_om -t start

20. 使用命令登录和进入数据库

gsql -d postgres -p 15400 -r

21. 创建一个自己的数据库

create database 数据库名称 with encoding '编码格式' template=template0;

b3d00d60df169fe4526c406d3d162bae.png 

22. 创建一个自己账号的用户

create user 用户名 password '密码';

23. 给用户授权,将默认的管理员权限赋予新用户

grant 管理员名称 to 用户名;

使用alter语句来给自己的用户授予权限:

alter user jack sysadmin;

这一步结束,你的GAUSS数据库就可以使用了。

<think>好的,用户现在想在CentOS 7安装配置Gauss数据库,我需要根据之前的对话提供的参考资料来生成一个详细的指南。首先,我需要回顾之前的回答,用户之前遇到了SSH安装的问题,现在转向数据库安装,可能需要考虑系统依赖环境配置。 首先,用户提供的引用中提到需要安装一些依赖包,比如gcc、net-tools、openssl-devel等,这可能是安装GaussDB的前提条件。我需要确保步骤中包含这些依赖的安装。另外,用户提到使用华为开发者空间周老师的分享,可能需要参考华为官方文档或社区资源。 接下来,用户可能已经解决了网络问题,但在安装数据库时可能会遇到新的依赖问题或配置错误。我需要分步骤指导,包括系统准备、依赖安装、下载GaussDB、配置环境、初始化数据库、远程连接等。同时,用户之前使用过Navicat进行远程连接,可能需要配置防火墙数据库权限。 需要注意的是,GaussDB有不同版本,用户可能指的是开源版还是企业版,引用中提到了企业版单节点安装,所以需要明确步骤适用于企业版。另外,用户的环境是CentOS 7,可能需要检查内核参数系统配置是否符合要求。 在编写步骤时,要确保命令正确,比如创建用户、设置环境变量、修改配置文件等。同时,要包含常见错误的解决方法,比如依赖缺失、权限问题、服务启动失败等。最后,提供验证安装成功的方法远程连接示例,帮助用户确认安装是否成功。 需要验证是否有遗漏的步骤,比如SELinux防火墙设置,这些在远程连接时很重要。另外,引用中提到的一些具体命令,如yum安装的软件包列表,需要包含在依赖安装步骤中。可能还需要提醒用户根据实际下载的安装版本调整命令中的文件名路径。 总结,整个指南需要结构清晰,逐步引导用户完成安装,并预见到可能的问题点,提供解决方案。同时,参考之前用户遇到的网络问题,确保依赖包安装时网络配置正确,避免再次出现DNS解析失败等问题。</think>### CentOS 7 高斯数据库GaussDB)安装与配置指南 --- #### 一、系统环境准备 1. **操作系统要求** - CentOS 7.6+(推荐 Minimal 安装- 内核版本:3.10.0-1160 或更高 - 磁盘空间:至少 50GB 空闲空间 - 内存:建议 8GB+(单节点测试环境最低 4GB) 2. **关闭防火墙与 SELinux** ```bash systemctl stop firewalld && systemctl disable firewalld setenforce 0 sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config # [^2] ``` 3. **配置主机名解析** ```bash echo "$(hostname -I | awk '{print $1}') $(hostname)" | sudo tee -a /etc/hosts ``` --- #### 二、安装依赖包 ```bash sudo yum install -y gcc net-tools wget openssl-devel bzip2-devel expat-devel \ gdbm-devel readline-devel sqlite-devel libaio-devel flex bison ncurses-devel \ glibc-devel patch redhat-lsb-core libnsl vim lrzsz bzip2 # [^2] ``` --- #### 三、高斯数据库安装企业版单节点) 1. **获取安装包** - 从[华为 GaussDB 官网](https://opengauss.org/zh/download.html)下载企业版安装包(如 `openGauss-3.0.0-CentOS-64bit.tar.gz`) 2. **创建安装用户** ```bash groupadd omm useradd -g omm -m omm echo "omm@123" | passwd --stdin omm # 设置密码(按需修改) ``` 3. **解压安装包** ```bash mkdir -p /opt/gaussdb tar -zxvf openGauss-3.0.0-CentOS-64bit.tar.gz -C /opt/gaussdb chown -R omm:omm /opt/gaussdb ``` 4. **配置环境变量** ```bash su - omm echo 'export GAUSSHOME=/opt/gaussdb' >> ~/.bashrc echo 'export PATH=$GAUSSHOME/bin:$PATH' >> ~/.bashrc source ~/.bashrc ``` 5. **初始化数据库** ```bash gs_initdb -D /opt/gaussdb/data --nodename=node1 \ --pwpasswd=Gauss@123456 # 设置数据库管理员密码[^1] ``` --- #### 四、启动与验证服务 1. **启动数据库** ```bash gs_ctl start -D /opt/gaussdb/data ``` 2. **检查运行状态** ```bash gs_ctl status -D /opt/gaussdb/data ``` - ✅ 正常输出应包含 `server is running` 3. **连接本地数据库** ```bash gsql -d postgres -p 5432 -U omm -W Gauss@123456 ``` --- #### 五、远程连接配置 1. **修改配置文件** ```bash vi /opt/gaussdb/data/pg_hba.conf ``` 添加允许远程访问的规则: ```conf host all all 0.0.0.0/0 sha256 # 允许所有IP连接 ``` 2. **开放监听地址** ```bash vi /opt/gaussdb/data/postgresql.conf ``` 修改参数: ```conf listen_addresses = '*' # 默认监听所有地址 port = 5432 ``` 3. **重启服务生效** ```bash gs_ctl restart -D /opt/gaussdb/data ``` --- #### 六、Navicat 远程连接示例 1. **连接参数** ```plaintext 主机:CentOS服务器IP 端口:5432 用户名:omm 密码:Gauss@123456 数据库:postgres ``` 2. **常见错误处理** | **错误类型** | **解决方案** | |--------------------------|--------------------------------------------------| | 连接超时 | 检查防火墙/云服务器安全组是否开放 5432 端口 | | 认证失败 | 检查 `pg_hba.conf` 中客户端IP段的 `md5/sha256` 设置 | | 找不到数据库 | 确认连接参数中的数据库名是否为 `postgres` | --- ### 安装流程图解 ```mermaid graph TD A[准备CentOS 7环境] --> B[安装依赖包] B --> C[创建omm用户] C --> D[解压安装包] D --> E[初始化数据库] E --> F[配置远程访问] F --> G[启动服务] G --> H[Navicat连接验证] ``` --- ### 关键配置文件说明 1. **`postgresql.conf`** - 核心参数:`max_connections`(默认100)、`shared_buffers`(建议设内存的25%) 2. **`pg_hba.conf`** - 控制客户端认证方式,格式:`host 数据库 用户 IP范围 认证方法` --- ### 常见问题排查 1. **初始化报错 "Failed to create directory"** ```bash chmod 755 /opt/gaussdb # 确保目录权限正确[^1] ``` 2. **服务启动报错 "Address already in use"** ```bash netstat -tunlp | grep 5432 # 查找占用端口的进程 kill -9 <PID> # 终止冲突进程 ``` 3. **性能优化建议** - 调整 `shared_buffers` `work_mem` 参数 - 使用 SSD 存储提升 I/O 性能 - 定期执行 `VACUUM ANALYZE` 维护数据库 --- ### 进阶操作 1. **数据库备份与恢复** ```bash # 全量备份 gs_dumpall -U omm -f /backup/full_backup.sql # 单库恢复 gsql -d postgres -U omm -W < /backup/full_backup.sql ``` 2. **日志监控** ```bash tail -f /opt/gaussdb/data/pg_log/postgresql-*.log ``` --- ### 引用说明 [^1]: 基于华为开发者社区与 优快云 多篇高斯数据库部署实践总结 [^2]: 华为 GaussDB 企业版安装手册要求的基础依赖项
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

周老师在此

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值