1、拉取percona-xtradb-cluster:5.7.21镜像
docker pull percona/percona-xtradb-cluster:5.7.21
docker tag percona/percona-xtradb-cluster:5.7.21 pxc
docker rmi -f percona/percona-xtradb-cluster
2、创建network
docker network create --subnet=172.16.0.0/24 che-net
docker network ls
docker network inspect che-net
3、创建volume
docker volume create --name che-v1
docker volume create --name che-v2
docker volume create --name che-v3
docker volume inspect che-v1
4、创那container
## 创建node1
docker run -d -p 3301:3306 -v che-v1:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=CHE-PXC -e XTRABACKUP_PASSWORD=123456 --privileged --name=node1 --net=che-net --ip 172.16.0.2 che-pxc
## 创建node2
docker run -d -p 3302:3306 -v che-v2:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=CHE-PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 --privileged --name=node2 --net=che-net --ip 172.16.0.3 che-pxc
## 创建node3
docker run -d -p 3303:3306 -v che-v3:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=CHE-PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 --privileged --name=node3 --net=che-net --ip 172.16.0.4 che-pxc
注意:创建node2、node3与创建node1的语句的不同,多了
-e CLUSTER_JOIN=node1
5、使用mysql数据库客户端工具进行测试
按照三个图的方式创建3个连接,node1、node2、node3,然后,再进行测试,在node1中新建一个数据库
6、通过haproxy实现mysql集群的负载均衡
拉取haproxy
docker pull haproxy
在宿主机/tmp/haproxy目录下新建haproxy.cfg文件,编辑内容为以下(注意理解server MySQL_1、server MySQL_2、server MySQL_3的ip和端口)(另外haproxy.cfg文件可以在windows编辑好后,直接上传到宿主机/tmp/haproxy目录下,我就是这样做的):
global
#工作目录,这边要和创建容器指定的目录对应
chroot /usr/local/etc/haproxy
#日志文件
log 127.0.0.1 local5 info
#守护进程运行
daemon
defaults
log global
mode http
#日志格式
option httplog
#日志中不记录负载均衡的心跳检测记录
option dontlognull
#连接超时(毫秒)
timeout connect 5000
#客户端超时(毫秒)
timeout client 50000
#服务器超时(毫秒)
timeout server 50000
#监控界面
listen admin_stats
#监控界面的访问的IP和端口
bind 0.0.0.0:8888
#访问协议
mode http
#URI相对地址
stats uri /dbs_monitor
#统计报告格式
stats realm Global\ statistics
#登陆帐户信息
stats auth admin:admin
#数据库负载均衡
listen proxy-mysql
#访问的IP和端口,haproxy开发的端口为3306
#假如有人访问haproxy的3306端口,则将请求转发给下面的数据库实例
bind 0.0.0.0:3306
#网络协议
mode tcp
#负载均衡算法(轮询算法)
#轮询算法:roundrobin
#权重算法:static-rr
#最少连接算法:leastconn
#请求源IP算法:source
balance roundrobin
#日志格式
option tcplog
#在MySQL中创建一个没有权限的haproxy用户,密码为空。
#Haproxy使用这个账户对MySQL数据库心跳检测
option mysql-check user haproxy
server MySQL_1 172.16.0.2:3306 check weight 1 maxconn 2000
server MySQL_2 172.16.0.3:3306 check weight 1 maxconn 2000
server MySQL_3 172.16.0.4:3306 check weight 1 maxconn 2000
#使用keepalive检测死链
option tcpka
创建安haproxy容器che-haproxy,使用che-net网络,端口号映射到宿主机的3309端口
docker run -it -d -p 8888:8888 -p 3309:3306 -v /tmp/haproxy:/usr/local/etc/haproxy --name che-haproxy --privileged --net=che-net haproxy
根据haproxy.cfg文件启动haproxy
docker exec -it che-haproxy bash
haproxy -f /usr/local/etc/haproxy/haproxy.cfg
在windows机器上输入http://192.168.1.9:8888/dbs_monitor,用户名、密码都为admin
haproxy的后台管理界面如下:
使用mysql客户端连接mysql集群,如下图