天天观焦点:Docker - 搭建Mysql PXC高可用集群环境部署
Docker 基本用法
1.安装 docker
(资料图片)
yum -y updateyum install -y docker
2.启动 / 关闭 / 重启 docker
service docker start / systemctl start dockerservice docker stop / systemctl stop dockerservice docker restart / systemctl restart docker
ps:我本地机器用第二个命令启动成功的。
3.配置docker镜像加速器
curl -sSL https://get.daocloud.io/daotools/set_mirror.sh |sh -s http://f1361db2.m.daocloud.io #linuxhttp://f1361db2.m.daocloud.io #macOshttp://f1361db2.m.daocloud.io #Windows
ps:设置如果报错,去配置文件修改,去掉最后的一个逗号,路径vim /etc/docker/daemon.json
, 修改配置完,最好重启docker,以避免不必要的错误。
如果是添加阿里云docker的加速器,开通加速服务在配置项里找到对应的命令,
sudo mkdir -p /etc/dockersudo tee /etc/docker/daemon.json <<-"EOF"{ "registry-mirrors": ["https://lgltjulp.mirror.aliyuncs.com"]}EOFsudo systemctl daemon-reloadsudo systemctl restart docker
4.查找并安装镜像
docker search java #查找镜像docker pull docker.io/java #安装你需要的镜像
5.查看docker中已经安装的镜像
docker images
6.导入和导出镜像
docker save docker.io/java > /home/docker/java.tar.gz #导出docker镜像docker load < /home/docker/java.tar.gz 导入docker镜像docker imagesdocker rmi java
7.启动容器
docker run -it docker.io/java bash -p 9000:8080 -p 9001:8085 # -p 映射宿主机和虚拟机的端口-v /home/project:/soft #-v 映射宿主机和虚拟机的文件夹--privileged # 目录权限--name myjava
docker run -it -p 9000:8080 -p 9001:8085 -v /home/project:/soft --privileged --name myjava docker.io/java bash
8.暂停和停止容器
docker pause myjava # 暂停容器docker unpause myjava #恢复容器的运行docker stop myjava #暂停容器docker start -i myjava #重启
9.查看运行的容器
docker ps -a docker run -it -p 9000:8080 -p 9001:8085 -v /home/project:/soft--privileged --name myjava docker.io/java bash
Mysql PXC集群环境部署
PXC集群特点:
同步复制,事务在所有的集群节点要么同时提交,要么同时不提交Replication采用异步复制,无法保证数据的一致性1.下载镜像
docker pull percona/percona-xtradb-cluster
2.出于安全考虑,需要给pxc集群实例创建docker内部网络
docker network create --subnet=172.20.1.0/24 net1docker network inspect net1docker network rm net1
ps:阿里云服务器没有成功???!!中间遇到了一个小问题,Error response from daemon
, 这个是因为172.18 的网段已经存在,可以docker network ls
查看,换一个网段就解决了
3.创建docker卷
docker volume create --name v1docker volume create --name v2docker volume create --name v3docker volume create --name v4docker volume create --name v5
4.查看docker卷信息
docker inspect v1#创建第一个节点docker run -d -p 3310:3306 -e MYSQL_ROOT_PASSWORD=123456-e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 --name=node1 --net=net1 --ip 172.20.1.2 pxc#创建第二个节点docker run -d -p 3311:3306 -e MYSQL_ROOT_PASSWORD=123456-e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456-e CLUSTER_JOIN=node1--name=node2 --net=net1 --ip 172.20.1.3 pxc#创建第三个节点docker run -d -p 3315:3306 -e MYSQL_ROOT_PASSWORD=123456-e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456-e CLUSTER_JOIN=node1 --name=node3 --net=net1 --ip 172.20.1.7 pxc#创建第四个节点docker run -d -p 3313:3306 -e MYSQL_ROOT_PASSWORD=123456-e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456-e CLUSTER_JOIN=node1 --name=node4 --net=net1 --ip 172.20.1.5 pxc#创建第五个节点docker run -d -p 3314:3306 -e MYSQL_ROOT_PASSWORD=123456-e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456-e CLUSTER_JOIN=node1--name=node5 --net=net1 --ip 172.20.1.6 pxc
ps:在这个地方又遇到了个问题,创建了5个node节点,但是只启动了2个,3个失败???暂时还不知道原因???启动的状态都为Exited???!!
使用这句命令全部启动实例docker ps -aq | xargs -I {} docker start {}
5.mysql的负载均衡haproxy
docker pull haproxy
6.实例化haproxy
docker run -it -d -p 4001:8888 -p 4002:3306 -v /home/soft/haproxy:/usr/local/etc/haproxy --name h1 --privileged --net=net1 --ip 172.20.1.10 haproxy
global#工作目录chroot /usr/local/etc/haproxy#日志文件,使用rsyslog服务中local5日志设备(/var/log/local5),等级infolog 127.0.0.1 local5 info#守护进程运行daemondefaultslogglobalmodehttp#日志格式optionhttplog#日志中不记录负载均衡的心跳检测记录optiondontlognull #连接超时(毫秒)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-mysql#访问的IP和端口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.20.1.2:3306 check weight 1 maxconn 2000 server MySQL_2 172.20.1.3:3306 check weight 1 maxconn 2000 server MySQL_3 172.20.1.7:3306 check weight 1 maxconn 2000 server MySQL_4 172.20.1.5:3306 check weight 1 maxconn 2000 server MySQL_5 172.20.1.6:3306 check weight 1 maxconn 2000#使用keepalive检测死链 option tcpka
7.登陆到交互容器里
docker exec -it h1 bash
8.安装keepalive 完成双机热备,登录haproxy,执行命令
apt-get updateapt-get install keepalived
9.配置keepalive,
#创建第2个Haproxy负载均衡服务器docker run -it -d -p 4003:8888 -p 4004:3306 -v /home/soft/haproxy:/usr/local/etc/haproxy --name h2 --privileged --net=net1 --ip 172.20.1.10 haproxy
vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 51 priority 100 advert_int 1 authentication { auth_type PASS auth_pass 123456 } virtual_ipaddress { 172.20.1.201 }}#启动Keepalivedservice keepalived start#宿主机执行ping命令ping 172.20.1.201
#创建第2个Haproxy负载均衡服务器docker run -it -d -p 4003:8888 -p 4004:3306 -v /home/soft/haproxy:/usr/local/etc/haproxy --name h2 --privileged --net=net1 --ip 172.20.1.11 haproxy#进入h2容器,启动Haproxydocker exec -it h2 bashhaproxy -f /usr/local/etc/haproxy/haproxy.cfg
-
天天观焦点:Docker - 搭建Mysql PXC高可用集群环境部署
腾讯云 2023-03-07
-
女儿得了甲流五天去三次医院,最长一次排队4个多小时看到凌晨1点多!几天后儿子也发烧,这位父亲果断作了一个决定-世界热推荐
都市快报橙柿互动 2023-03-07
-
孕妇每天吃几个核桃合适_孕妇每天吃几个核桃
互联网 2023-03-07
-
如何查看聊天记录
万年历 2023-03-06
-
美股异动 | 苹果(AAPL.US)涨超2% 高盛6年来首次建议买入苹果
格隆汇 2023-03-06
-
内瓦尔
互联网 2023-03-06
-
破门并造点!官方:三笘薰当选海鸥vs西汉姆联的队内最佳球员_焦点资讯
懂球帝 2023-03-06
-
焦点播报:萧山交通投资:5.00亿元中期票据获准注册
东方财富Choice数据 2023-03-06
-
一磅等于多少克-焦点速讯
互联网 2023-03-06
-
卧龙苍天陨落黄天凶妖寨旗帜位置图大全,黄天凶妖寨牙旗在哪?|播资讯
哔哩哔哩 2023-03-06
-
天天观焦点:Docker - 搭建Mysql PXC高可用集群环境部署
腾讯云 2023-03-07
-
女儿得了甲流五天去三次医院,最长一次排队4个多小时看到凌晨1点多!几天后儿子也发烧,这位父亲果断作了一个决定-世界热推荐
都市快报橙柿互动 2023-03-07
-
孕妇每天吃几个核桃合适_孕妇每天吃几个核桃
互联网 2023-03-07
-
如何查看聊天记录
万年历 2023-03-06
-
美股异动 | 苹果(AAPL.US)涨超2% 高盛6年来首次建议买入苹果
格隆汇 2023-03-06
-
内瓦尔
互联网 2023-03-06
-
破门并造点!官方:三笘薰当选海鸥vs西汉姆联的队内最佳球员_焦点资讯
懂球帝 2023-03-06
-
焦点播报:萧山交通投资:5.00亿元中期票据获准注册
东方财富Choice数据 2023-03-06
-
一磅等于多少克-焦点速讯
互联网 2023-03-06
-
卧龙苍天陨落黄天凶妖寨旗帜位置图大全,黄天凶妖寨牙旗在哪?|播资讯
哔哩哔哩 2023-03-06
-
天天新消息丨TOMMY HILFIGER继续扩大其中国童装市场版图,青岛童装新店已盛大开业
东方网 2023-03-06
-
今日热议:流金岁月电视剧蒋南孙和谁在一起了
万年历 2023-03-06
-
中国光大银行石家庄广安大街支行获得2022年省级“最美工会户外劳动者服务站点”称号-热头条
河北新闻网 2023-03-06
-
咨询工程师哪个老师的课最好_咨询工程师哪个老师讲的好-世界今热点
互联网 2023-03-06
-
观焦点:有了TCL Q10洗衣机,再也不怕回南天了
中国娱乐网 2023-03-06
-
河北衡水武邑县都有什么高中 全球新动态
万年历 2023-03-06
-
头条:中信建投:国内流感抬头,产业链相关公司可能均有受益
和讯崔晨 2023-03-06
-
讯息:今日豪华传送门如何开_豪华传送门
互联网 2023-03-06
-
全球观点:女主是明星后来嫁入豪门的小说
万年历 2023-03-05
-
环球讯息:pdp架子鼓有哪些系列_PDP是什么牌子架子鼓
互联网 2023-03-05
-
通讯!冉冰是什么动漫
万年历 2023-03-05
-
每日资讯:介绍川菜藿香鲫鱼的做法
康之道 2023-03-05
-
世界速读:广州市普通话测试站_广州中医药大学普通话测试站
互联网 2023-03-05
-
溃败!蔚来去年巨亏144亿,报表没法看,李斌没得选|全球今头条
说财猫 2023-03-05
-
一光年等于多少米_一光年等于多少千米
互联网 2023-03-05
-
中央子午线的计算方法例题_中央子午线计算方法
互联网 2023-03-05
-
当前热门:夜来香歌词含义_夜来香歌词
互联网 2023-03-05
-
世界播报:豆瓣8.3分,全网催第二部
新周刊 2023-03-05
-
03S-环球消息
互联网 2023-03-04
-
当前短讯!一周债市看点 | 中国奥园部分境外债暂缓偿还 贵州水城水务3亿债务逾期
界面新闻 2023-03-04