1 第一步 利用docker 拉取pxc镜像, 生成4个mysql节点
1. 安装PXC镜像
docker pull percona/percona-xtradb-cluster
2. 给镜像改名
docker tag percona/percona-xtradb-cluster pxc
3. 创建net1网段:
docker network create --subnet=172.18.0.0/16 net1
4.创建4个数据卷
(pxc无法直接存取宿组机的数据,所以创建4个docker数据卷)
docker volume create v1
docker volume create v2
docker volume create v3
docker volume create v4
docker volume create v5
ps 如果要删除数据卷 命令 docker volume rm v3
5. 查看数据卷位置:
docker inspect v1
6. 创建四节点的PXC集群
docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -v v1:/var/lib/mysql -v backup:/data --privileged --name=node1 --net=net1 --ip 172.18.0.2 pxc
等待2分钟后,再创建第二个节点,等待第一个节点实例化完毕后,才能开启第二个节点实例,不然会瞬间停止
创建其他节点:
#创建第2个MySQL节点
docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 -v v2:/var/lib/mysql -v backup:/data --privileged --name=node2 --net=net1 --ip 172.18.0.3 pxc
#创建第3个MySQL节点
docker run -d -p 3308:3306 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 -v v3:/var/lib/mysql --privileged --name=node3 --net=net1 --ip 172.18.0.4 pxc
#创建第4个MySQL节点
docker run -d -p 3309:3306 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 -v v4:/var/lib/mysql --privileged --name=node4 --net=net1 --ip 172.18.0.5 pxc
7. 利用navcat分别连接四个mysql, 连接成功,测试一下数据同步 没问题的话,mysql 的四个节点搞定了
2 第二步利用docker 拉取haproxy镜像 , 安装Haproxy进行高可用与负载均衡
1. 拉取haproxy
docker pull haproxy
2. 编写Haproxy配置文件
vi /home/soft/haproxy.cfg
global
#工作目录
chroot /usr/local/etc/haproxy
#日志文件,使用rsyslog服务中local5日志设备(/var/log/local5),等级info
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
#统计报告格式
stats realm Global\ statistics
#登陆帐户信息
stats auth admin:abc123456
#数据库负载均衡
listen proxy-mysql1
#访问的IP和端口
bind 0.0.0.0:8806
#网络协议
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
server MySQL_2 172.18.0.3:3306
#使用keepalive检测死链
option tcpka
#数据库负载均衡
listen proxy-mysql2
#访问的IP和端口
bind 0.0.0.0:8807
#网络协议
mode tcp
#负载均衡算法(轮询算法)
#轮询算法:roundrobin
#权重算法:static-rr
#最少连接算法:leastconn
#请求源IP算法:source
balance roundrobin
#日志格式
option tcplog
#在MySQL中创建一个没有权限的haproxy用户,密码为空。Haproxy使用这个账户对MySQL数据库心跳检测
#option mysql-check user haproxy
server MySQL_3 172.18.0.4:3306
server MySQL_4 172.18.0.5:3306
#使用keepalive检测死链
option tcpka
3.创建第1个Haproxy负载均衡服务器
docker run -it -d -p 4001:8888 -p 8888:8806 -p 8889:8807 -v /home/soft/haproxy:/usr/local/etc/haproxy --name h1 --privileged --net=net1 --ip 172.18.0.7 haproxy
4.进入h1容器,启动Haproxy
docker exec -it h1 bash
haproxy -f /usr/local/etc/haproxy/haproxy.cfg
5. 查看是否启动 ip:4001/dbs

网友评论