Docker Proxy MySQL负载均衡
#创建一个docker的单独网段,与mysql数据库集群共同使用
#创建docker网段
docker network create --subnet=172.18.0.0/24 pxc-net
#查看网络情况
docket network inspect pxc-net
#获取取pxc镜像
docker pull percona/percona-xtradb-cluster:5.7.21
#重新打标pxc镜像(重命名)
docker tag percona/percona-xtradb-cluster:5.7.21 pxc
#创建volume数据卷(挂载点)
docker volume create --name v1
docker volume create --name v2
docker volume create --name v3
#用镜像创建并运行三个pxc容器
#其中:
#CLUSTER_NAME=PXC;集群名字
#XTRABACKUP_PASSWORD;数据库同步需要用到的密码
#node1
docker run -d -p 3301:3306 -v v1:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=root --privileged \
--name=node1 --net=pxc-net --ip 172.18.0.2 pxc
#node2
docker run -d -p 3302:3306 -v v2:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=root \
-e CLUSTER_JOIN=node1 --privileged \
--name=node2 --net=pxc-net --ip 172.18.0.3 pxc
#node3
docker run -d -p 3303:3306 -v v3:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=root \
-e CLUSTER_JOIN=node1 --privileged \
--name=node3 --net=pxc-net --ip 172.18.0.4 pxc
#获取取haproxy镜像
docker pull haproxy
#创建并编辑haproxy配置文件,这里使用bind mounting的方式(bind mounting 只需要 -v 指明 容器外部文件夹和容器映射文件夹的对应关系即可 将本地的文件映射到容器内,-v参数后面,:号左边是本地)
touch /tmp/haproxy/haproxy.cfg
vim /tmp/haproxy/haproxy.cfg
#以下为配置文件内容
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.18.0.2:3306 check weight 1 maxconn 2000
server MySQL_2 172.18.0.3:3306 check weight 1 maxconn 2000
server MySQL_3 172.18.0.4:3306 check weight 1 maxconn 2000
#使用keepalive检测死链
option tcpka
#启动haproxy容器
docker run -d -p 8888:8888 -p 3309:3306 \
-v /tmp/haproxy:/usr/local/etc/haproxy \
--name haproxy01 --privileged --net=pxc-net haproxy
#此时能打开网页,但mysql客户端是连接不上haproxy的,需要根据配置文件启动haproxy,并在数据库上创建用户用于检测心跳
#加载haproxy.cfg文件启动haproxy
#其中 -f 是指定我们的配置文件的路径
docker exec -it haproxy01 bash
容器内执行:
haproxy -f /usr/local/etc/haproxy/haproxy.cfg
#在node1容器MySQL数据库上创建用户,用于心跳检测
CREATE USER 'haproxy'@'%' IDENTIFIED BY '';
#测试访问地址,浏览器里打开,账号密码参考配置文件
(http://)ip:8888/dbs_monitor
#遇见过的问题:
1、mysql上用户创建失败;
处理方法(删除用户刷新后新建):
drop user 'haproxy'@'%';
flush privileges;
CREATE USER 'haproxy'@'%' IDENTIFIED BY '';
2、node节点起不来;
node1容器起来后维持不到一分钟自动down,其他节点直接起不来;
处理方法(删除node1的volume和容器后重建)
另:有错可以参考错误日志
docker logs container_id
参考链接:https://zhuanlan.zhihu.com/p/93857211
该博客详细介绍了如何在Docker环境下创建Percona XtraDB Cluster数据库集群,并通过Haproxy实现负载均衡。首先创建Docker网络,然后拉取并重命名pxc镜像,创建数据卷,依次启动三个pxc容器作为集群节点。接着,获取haproxy镜像,编写并应用haproxy配置文件,设置监听和负载均衡策略。最后,启动haproxy容器并创建MySQL数据库用户进行心跳检测。过程中还提到了可能遇到的问题及解决方法,如用户创建失败和节点无法启动等。
833

被折叠的 条评论
为什么被折叠?



