-
Notifications
You must be signed in to change notification settings - Fork 700
/
start_mysql.sh
44 lines (40 loc) · 3.57 KB
/
start_mysql.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# start up mysql
docker network create --driver bridge --subnet 192.167.0.0/16 --gateway 192.167.0.1 net-mysql
docker run --name dn1_host1 --restart always --net net-mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -v /home/mysql/dn1_host1:/var/lib/mysql -d zongxr/mysql:5.7.37
# each mysql node sleep 1s for the reason that we set second timestamp to server-id
sleep 1s
docker run --name dn1_host2 --restart always --net net-mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=root -v /home/mysql/dn1_host2:/var/lib/mysql -d zongxr/mysql:5.7.37
sleep 1s
docker run --name dn2_host1 --restart always --net net-mysql -p 3308:3306 -e MYSQL_ROOT_PASSWORD=root -v /home/mysql/dn2_host1:/var/lib/mysql -d zongxr/mysql:5.7.37
sleep 1s
docker run --name dn2_host2 --restart always --net net-mysql -p 3309:3306 -e MYSQL_ROOT_PASSWORD=root -v /home/mysql/dn2_host2:/var/lib/mysql -d zongxr/mysql:5.7.37
sleep 10s
# exec the DDL
docker exec dn1_host1 mysql -uroot -proot -e "$(cat ./ddl.sql)"
docker exec dn1_host2 mysql -uroot -proot -e "$(cat ./ddl.sql)"
docker exec dn2_host1 mysql -uroot -proot -e "$(cat ./ddl.sql)"
docker exec dn2_host2 mysql -uroot -proot -e "$(cat ./ddl.sql)"
# mount master and slave
dn1_host1_file=$(docker exec dn1_host1 mysql -uroot -proot -e "show master status;" | awk '{print $1}' | tail -n 1)
dn1_host1_pos=$(docker exec dn1_host1 mysql -uroot -proot -e "show master status;" | awk '{print $2}' | tail -n 1)
dn1_host2_file=$(docker exec dn1_host2 mysql -uroot -proot -e "show master status;" | awk '{print $1}' | tail -n 1)
dn1_host2_pos=$(docker exec dn1_host2 mysql -uroot -proot -e "show master status;" | awk '{print $2}' | tail -n 1)
dn2_host1_file=$(docker exec dn2_host1 mysql -uroot -proot -e "show master status;" | awk '{print $1}' | tail -n 1)
dn2_host1_pos=$(docker exec dn2_host1 mysql -uroot -proot -e "show master status;" | awk '{print $2}' | tail -n 1)
dn2_host2_file=$(docker exec dn2_host2 mysql -uroot -proot -e "show master status;" | awk '{print $1}' | tail -n 1)
dn2_host2_pos=$(docker exec dn2_host2 mysql -uroot -proot -e "show master status;" | awk '{print $2}' | tail -n 1)
docker exec dn1_host1 mysql -uroot -proot -e "CHANGE MASTER TO MASTER_HOST='dn1_host2', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_POS=${dn1_host2_pos}, MASTER_LOG_FILE='"${dn1_host2_file}"';"
docker exec dn1_host2 mysql -uroot -proot -e "CHANGE MASTER TO MASTER_HOST='dn1_host1', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_POS=${dn1_host1_pos}, MASTER_LOG_FILE='"${dn1_host1_file}"';"
docker exec dn2_host1 mysql -uroot -proot -e "CHANGE MASTER TO MASTER_HOST='dn2_host2', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_POS=${dn2_host2_pos}, MASTER_LOG_FILE='"${dn2_host2_file}"';"
docker exec dn2_host2 mysql -uroot -proot -e "CHANGE MASTER TO MASTER_HOST='dn2_host1', MASTER_PORT=3306, MASTER_USER='root', MASTER_PASSWORD='root', MASTER_LOG_POS=${dn2_host1_pos}, MASTER_LOG_FILE='"${dn2_host1_file}"';"
docker exec dn1_host1 mysql -uroot -proot -e "show slave status;start slave;"
docker exec dn1_host2 mysql -uroot -proot -e "show slave status;start slave;"
docker exec dn2_host1 mysql -uroot -proot -e "show slave status;start slave;"
docker exec dn2_host2 mysql -uroot -proot -e "show slave status;start slave;"
# start up mycat
mkdir -p /home/mysql/mycat/conf
cp ../mycat/conf /home/mysql/mycat
docker run --name mycat --restart always --net net-mysql -p 8066:8066 -p 9066:9066 -v /home/mysql/mycat/conf:/opt/mycat/conf -d zongxr/mycat:1.15.1
sleep 5s
# insert data
docker exec dn1_host1 mysql -uroot -proot -h mycat -P 8066 -e "$(cat ./data.sql)"