本文小編為大家詳細介紹“docker搭建MySQL集群的方法是什么”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“docker搭建Mysql集群的方法是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
公司專注于為企業(yè)提供網(wǎng)站設計、網(wǎng)站制作、微信公眾號開發(fā)、成都商城網(wǎng)站開發(fā),微信小程序開發(fā),軟件按需策劃設計等一站式互聯(lián)網(wǎng)企業(yè)服務。憑借多年豐富的經(jīng)驗,我們會仔細了解各客戶的需求而做出多方面的分析、設計、整合,為客戶設計出具風格及創(chuàng)意性的商業(yè)解決方案,創(chuàng)新互聯(lián)公司更提供一系列網(wǎng)站制作和網(wǎng)站推廣的服務。
docker基本指令:
更新軟件包
yum -y update
安裝docker虛擬機(centos 7)
yum install -y docker
運行、重啟、關閉docker虛擬機
service docker start service docker stop
搜索鏡像
docker search 鏡像名稱
下載鏡像
docker pull 鏡像名稱
查看鏡像
docker images
刪除鏡像
docker rmi 鏡像名稱
運行容器
docker run 啟動參數(shù) 鏡像名稱
查看容器列表
docker ps -a
當我們想要使用java環(huán)境,我們可以這么操作:
搜索: [root@vm_71_225_centos ~]# docker search java index name description stars official automated docker.io docker.io/node node.js is a javascript-based platform for... 5752 [ok] docker.io docker.io/tomcat apache tomcat is an open source implementa... 1891 [ok] docker.io docker.io/java java is a concurrent, class-based, and obj... 1745 [ok] docker.io docker.io/openjdk openjdk is an open-source implementation o... 1031 [ok]
下載: [root@vm_71_225_centos ~]# docker pull docker.io/java using default tag: latest trying to pull repository docker.io/library/java ... latest: pulling from docker.io/library/java 5040bd298390: downloading [=> ] 1.572 mb/51.36 mb
運行: [root@vm_71_225_centos ~]# docker run -it --name myjava docker.io/java bash root@25623e12b759:/# java -i: 以交互模式運行容器,通常與 -t 同時使用; -t: 為容器重新分配一個偽輸入終端,通常與 -i 同時使用;
安裝pxc集群(在此不做mysql pxc集群與replication集群的方案優(yōu)劣說明,在此選用pxc集群方案[多節(jié)點備份與強聯(lián)合性]):
安裝pxc鏡像
docker pull percona/percona-xtradb-cluster
查看本地鏡像
[root@vm_71_225_centos ~]# docker images repository tag image id created size docker.io/hello-world latest e38bc07ac18e 2 months ago 1.85 kb docker.io/percona/percona-xtradb-cluster latest f1439de62087 3 months ago 413 mb docker.io/java latest d23bdf5b1b1b 17 months ago 643 mb
docker.io/percona/percona-xtradb-cluster 太長,進行改名:
[root@vm_71_225_centos ~]# docker tag percona/percona-xtradb-cluster pxc [root@vm_71_225_centos ~]# docker images repository tag image id created size docker.io/hello-world latest e38bc07ac18e 2 months ago 1.85 kb docker.io/percona/percona-xtradb-cluster latest f1439de62087 3 months ago 413 mb pxc latest f1439de62087 3 months ago 413 mb docker.io/java latest d23bdf5b1b1b 17 months ago 643 mb
創(chuàng)建net1網(wǎng)段:
docker network create --subnet=172.18.0.0/16 net1
創(chuàng)建五個數(shù)據(jù)卷(pxc無法直接存取宿組機的數(shù)據(jù),所以創(chuàng)建五個docker數(shù)據(jù)卷)
docker volume create v1 docker volume create v2 docker volume create v3 docker volume create v4 docker volume create v5
查看數(shù)據(jù)卷位置:
[root@vm_71_225_centos code]# docker inspect v1 [ { "driver": "local", "labels": {}, "mountpoint": "/var/lib/docker/volumes/v1/_data", "name": "v1", "options": {}, "scope": "local" } ]
創(chuàng)建5節(jié)點的pxc集群
#創(chuàng)建第1個mysql節(jié)點 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分鐘后,再創(chuàng)建第二個節(jié)點,等待第一個節(jié)點實例化完畢后,才能開啟第二個節(jié)點實例,不然會瞬間停止
創(chuàng)建其他節(jié)點:
#創(chuàng)建第2個mysql節(jié)點 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 #創(chuàng)建第3個mysql節(jié)點 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 #創(chuàng)建第4個mysql節(jié)點 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 #創(chuàng)建第5個mysql節(jié)點 docker run -d -p 3310:3306 -e mysql_root_password=abc123456 -e cluster_name=pxc -e xtrabackup_password=abc123456 -e cluster_join=node1 -v v5:/var/lib/mysql -v backup:/data --privileged --name=node5 --net=net1 --ip 172.18.0.6 pxc
測試在任意mysql節(jié)點創(chuàng)建數(shù)據(jù)庫:
mysql -h 172.18.0.3 -uroot -pabc123456 mysql> create database test; query ok, 1 row affected (0.03 sec)
登錄其他節(jié)點數(shù)據(jù)庫,能看到已經(jīng)進行了同步,構(gòu)成簡單的mysql集群
安裝haproxy進行高可用與負載均衡
拉取haproxy
docker pull haproxy
編寫haproxy配置文件
vi /home/soft/haproxy.cfg
配置文件如下:
global #工作目錄 chroot /usr/local/etc/haproxy #日志文件,使用rsyslog服務中l(wèi)ocal5日志設備(/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 #監(jiān)控界面 listen admin_stats #監(jiān)控界面的訪問的ip和端口 bind 0.0.0.0:8888 #訪問協(xié)議 mode http #uri相對地址 stats uri /dbs #統(tǒng)計報告格式 stats realm global\ statistics #登陸帳戶信息 stats auth admin:abc123456 #數(shù)據(jù)庫負載均衡 listen proxy-mysql #訪問的ip和端口 bind 0.0.0.0:3306 #網(wǎng)絡協(xié)議 mode tcp #負載均衡算法(輪詢算法) #輪詢算法:roundrobin #權(quán)重算法:static-rr #最少連接算法:leastconn #請求源ip算法:source balance roundrobin #日志格式 option tcplog #在mysql中創(chuàng)建一個沒有權(quán)限的haproxy用戶,密碼為空。haproxy使用這個賬戶對mysql數(shù)據(jù)庫心跳檢測 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 server mysql_4 172.18.0.5:3306 check weight 1 maxconn 2000 server mysql_5 172.18.0.6:3306 check weight 1 maxconn 2000 #使用keepalive檢測死鏈 option tcpka
創(chuàng)建第1個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.18.0.7 haproxy
進入h1容器,啟動haproxy
docker exec -it h1 bash haproxy -f /usr/local/etc/haproxy/haproxy.cfg
查看是否啟動成功:
訪問http://ip:4001/dbs
安裝keepalive實現(xiàn)雙擊熱備
讀到這里,這篇“docker搭建Mysql集群的方法是什么”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內(nèi)容的文章,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。