使用docker创建mysql集群,并通过haproxy实现mysql集群的负载均衡

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集群,如下图
在这里插入图片描述

发布了122 篇原创文章 · 获赞 152 · 访问量 112万+

猜你喜欢

转载自blog.csdn.net/ytangdigl/article/details/103675266