一主两备不带cm安装_容器
本章节主要介绍通过Docker安装和升级一主两备不带cm的openGauss,方便用户了解步骤。
Docker安装一主两备不带cm的openGauss步骤
以root身份登录节点。
创建openGauss docker镜像(参考单节点容器安装镜像创建)
sh buildDockerImage.sh -v 6.0.0 -i
创建容器路径映射目录
mkdir -p /opt/test/{dn_6001,dn_6002,dn_6003}
修改create_master_slave.sh脚本,添加路径映射
sed -i '/^SLAVE_COUNT=1$/a MASTER_OUT_DIR="/opt/test/dn_6001"\nSLAVE_OUT_DIR=("/opt/test/dn_6002" "/opt/test/dn_6003")' create_master_slave.sh sed -i '/-e GS_PORT=$MASTER_HOST_PORT/i -v $MASTER_OUT_DIR:/var/lib/opengauss \\' create_master_slave.sh sed -i '/-e GS_PORT=$local_port/i \ -v ${SLAVE_OUT_DIR[$i]}:/var/lib/opengauss \\' create_master_slave.sh
执行脚本创建容器集群
bash create_master_slave.sh --SLAVE_COUNT 2 --NETWORK_NAME net_600 --VERSION 6.0.0 --MASTER_HOST_PORT 4432
创建完成后,查询集群状态
docker exec dn_6001 su - omm -c "gs_ctl query -D /var/lib/opengauss/data"
Docker升级一主两备不带cm的openGauss步骤
以root身份登录节点。
创建一主两备不带cm容器集群(参考上述安装步骤)
创建希望升级版本的openGauss docker镜像
准备升级工具目录及新包(以数据库3.0.5升级6.0.0为例)
创建upgrade目录,在upgrade目录中将新版本升级脚本和版本文件放在其中,即复制目标版本号目录下的upgrade_sql.*、version.cfg到pkg_new下
以
/opt/test/docker/upgrade
路劲为例,该目录下有以下文件和目录:pkg_new README.md upgrade_common.sh upgrade_errorcode.sh upgrade.sh
/opt/test/docker/upgrade/pkg_new
路径下为:upgrade_sql.sha256 upgrade_sql.tar.gz version.cfg
将升级工具包拷贝到容器内
docker cp /opt/test/docker/upgrade dn_6001:/var/lib/opengauss/ docker exec dn_6001 chown omm:omm /var/lib/opengauss/upgrade/ -R docker exec dn_6001 ls -al /var/lib/opengauss/upgrade docker cp /opt/test/docker/upgrade dn_6002:/var/lib/opengauss/ docker cp /opt/test/docker/upgrade dn_6003:/var/lib/opengauss/ docker exec dn_6002 chown omm:omm /var/lib/opengauss/upgrade/ -R docker exec dn_6002 ls -al /var/lib/opengauss/upgrade docker exec dn_6003 chown omm:omm /var/lib/opengauss/upgrade/ -R docker exec dn_6003 ls -al /var/lib/opengauss/upgrade
所有节点执行前置升级
docker exec dn_6001 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_pre" docker exec dn_6002 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_pre" docker exec dn_6003 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_pre"
停掉所有容器
docker exec dn_6003 su - omm -c "gs_ctl stop -D /var/lib/opengauss/data/" docker exec dn_6002 su - omm -c "gs_ctl stop -D /var/lib/opengauss/data/" docker exec dn_6001 su - omm -c "gs_ctl stop -D /var/lib/opengauss/data/"
启动新版本容器并执行
分别开3个窗口执行,不要退出,后续还需要在这里执行
docker run --network net_305 --ip 172.11.0.101 --privileged=true --name dn_6001_600 -h dn_6001 -p 4432:4432 -v /opt/test/dn_6001:/var/lib/opengauss -it --entrypoint /bin/bash opengauss:6.0.0 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_bin" docker run --network net_305 --ip 172.11.0.102 --privileged=true --name dn_6002_600 -h dn_6002 -p 6432:6432 -v /opt/test/dn_6002:/var/lib/opengauss -it --entrypoint /bin/bash opengauss:6.0.0 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_bin" docker run --network net_305 --ip 172.11.0.103 --privileged=true --name dn_6003_600 -h dn_6002 -p 7432:7432 -v /opt/test/dn_6003:/var/lib/opengauss -it --entrypoint /bin/bash opengauss:6.0.0 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_bin"
所有节点执行后置升级
su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_post"
回退操作(可选)
在新版本容器中
#已执行upgrade_post动作 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t rollback_post" #已执行upgrade_bin动作 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t rollback_bin"
退出新版本容器,通过
docker ps -a
命令找到旧版本容器CONTAINER ID
#启动旧版本容器 docker start <CONTAINER ID> #进入容器 docker exec -ti <CONTAINER ID> /bin/bash #已执行upgrade_pre动作 su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t rollback_pre"
升级提交
su - omm -c "sh /var/lib/opengauss/upgrade/upgrade.sh -B /var/lib/opengauss/upgrade -N /var/lib/opengauss/upgrade/pkg_new -t upgrade_commit"
意见反馈