Rumah > pangkalan data > tutorial mysql > Apakah kaedah untuk membina kluster Mysql dengan docker?

Apakah kaedah untuk membina kluster Mysql dengan docker?

WBOY
Lepaskan: 2023-05-29 13:55:06
ke hadapan
1610 orang telah melayarinya

Arahan docker asas:

Kemas kini pakej perisian

yum -y update
Salin selepas log masuk

Pasang mesin maya docker (centos 7)

yum install -y docker
Salin selepas log masuk

Jalankan, mulakan semula dan tutup Down docker Mesin maya

service docker start
service docker stop
Salin selepas log masuk

Cari imej

docker search 镜像名称
Salin selepas log masuk

Muat turun imej

docker pull 镜像名称
Salin selepas log masuk

Lihat imej

docker images
Salin selepas log masuk

Padam imej

docker rmi 镜像名称
Salin selepas log masuk

Jalankan bekas

docker run 启动参数 镜像名称
Salin selepas log masuk

Lihat senarai bekas

docker ps -a
Salin selepas log masuk

Apabila kita ingin menggunakan persekitaran java, kita boleh melakukan ini:

搜索:
[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]
Salin selepas log masuk
下载:
[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
Salin selepas log masuk
运行:
[root@vm_71_225_centos ~]# docker run -it --name myjava docker.io/java bash
root@25623e12b759:/# java


-i: 以交互模式运行容器,通常与 -t 同时使用;


-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
Salin selepas log masuk

Pasang gugusan pxc (kami tidak akan lakukan kluster dan replikasi mysql pxc di sini) Kelebihan dan keburukan penyelesaian kluster diterangkan Di sini kita memilih penyelesaian kluster pxc [sandaran berbilang nod dan persekutuan kuat]):

Pasang imej pxc<. 🎜>

docker pull percona/percona-xtradb-cluster
Salin selepas log masuk

Lihat imej setempat

[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
Salin selepas log masuk

docker.io/percona/percona-xtradb-cluster terlalu panjang, tukar nama:

[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
Salin selepas log masuk

Buat segmen rangkaian net1:

docker network create --subnet=172.18.0.0/16 net1
Salin selepas log masuk

Buat lima volum data (pxc tidak boleh mengakses terus Hos data mesin kumpulan, jadi buat lima volum data docker)

docker volume create v1
docker volume create v2
docker volume create v3
docker volume create v4
docker volume create v5
Salin selepas log masuk

Lihat lokasi volum data:

[root@vm_71_225_centos code]# docker inspect v1
[
  {
    "driver": "local",
    "labels": {},
    "mountpoint": "/var/lib/docker/volumes/v1/_data",
    "name": "v1",
    "options": {},
    "scope": "local"
  }
]
Salin selepas log masuk

Buat gugusan pxc 5-nod

#创建第1个mysql节点
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
Salin selepas log masuk

Selepas menunggu selama 2 minit , kemudian buat nod kedua, dan tunggu sehingga nod pertama disegerakan sebelum membuka contoh nod kedua, jika tidak, ia akan berhenti serta-merta

Buat nod lain:

#创建第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
#创建第5个mysql节点
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
Salin selepas log masuk

Uji di mana-mana nod Mysql mencipta pangkalan data:

mysql -h 172.18.0.3 -uroot -pabc123456

mysql> create database test;
query ok, 1 row affected (0.03 sec)
Salin selepas log masuk

Log masuk ke pangkalan data nod lain dan anda boleh melihat bahawa ia telah disegerakkan untuk membentuk gugusan mysql mudah

Pasang haproxy untuk ketersediaan tinggi dan pengimbangan beban

Tarik haproxy

docker pull haproxy
Salin selepas log masuk

Tulis fail konfigurasi haproxy

vi /home/soft/haproxy.cfg
Salin selepas log masuk

Fail konfigurasi adalah sebagai berikut:

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-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.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
Salin selepas log masuk

Buat pelayan pengimbangan beban haproksi pertama

Salin kod Kod adalah seperti berikut:

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

Masukkan bekas h1, mulakan haproxy

docker exec -it h1 bash
haproxy -f /usr/local/etc/haproxy/haproxy.cfg
Salin selepas log masuk
untuk menyemak sama ada permulaan berjaya:

Lawati http:// ip:4001/dbs

Apakah kaedah untuk membina kluster Mysql dengan docker?

Pasang keepalive ke capai sandaran panas klik dua kali

Atas ialah kandungan terperinci Apakah kaedah untuk membina kluster Mysql dengan docker?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan