docker run -p 5432:5432 -e 'GAUSS_USER=gauss' -e 'GAUSS_PASSWORD=Gauss666' -d --name OpenGaussTest lsqtzj/openeuler_open_gauss:latest
openGauss 极简版 基于openeuler/openeuler:20.03
包括 patroni自动主备切换,haproxy 负载均衡, pgAdmin4 管理工具
必须保证有两个以上的openGauss容器运行。
https://blog.csdn.net/lsqtzj/article/details/120850420
下载源码
git clone https://github.com/CyrusZhou-CN/openGauss_master_slave.git
cd openGauss_master_slave
docker-compose -f "docker-compose-build.yml" up -d --build
docker-compose -f "docker-compose.yml" up -d
用户名/密码 root / root 、omm / omm
管理员 / 密码:gauss / Gauss666
http://localhost:9980/pgadmin4/browser/
默认管理员 / 密码:admin@domain.com / admin
etcd Version: 3.5.1
patroni Version 2.0.2
haproxy:5000 读写
haproxy:5001 读
docker-compose 基本配置 放到 .env 文件中。
默认保存在 ./data 目录
/opt/software/openGauss/data/db 数据库目录 /opt/software/openGauss/data/conf 配置文件目录 /opt/software/openGauss/logs 日志目录
如:新添加 slave03 主机,打开docker-compose.yml 文件复制 slave02 节点的配置,用来创建新主机。
...
slave03:
image: lsqtzj/openeuler_open_gauss:${OPEN_GAUSS_VERSION}
restart: always
container_name: slave03
hostname: slave03
networks:
gauss:
ipv4_address: 10.8.0.13
environment:
TZ: Europe/Rome #Asia/Shanghai 时区
GAUSS_USER: ${GAUSS_USER}
GAUSS_PASSWORD: ${GAUSS_PASSWORD}
NODE_NAME: datanode4
RUN_MODE: "slave"
HOST_NAMES: ${HOST_NAMES}
volumes:
- ./data/slave03/data:/opt/software/openGauss/data
- ./data/slave03/logs:/opt/software/openGauss/logs
depends_on:
- master
...
修改 .env 文件添加新主机
...
HOST_NAMES=master,slave01,slave02,slave03
HOST_IPS=10.8.0.10,10.8.0.11,10.8.0.12
HAPROXY_IPS=10.8.0.10,10.8.0.11,10.8.0.12,10.8.0.13
HAPROXY_PORTS=5432,5432,5432,5432
...
volumes:
- ./test.sql:/docker-entrypoint-initdb.d/test.sql # 初始化数据表