Используйте докер для конфигурации master-slave базы данных, потому что у меня есть это требование, но после поиска в Интернете я обнаружил, что нет соответствующих практических документов, отвечающих моим потребностям, а некоторые являются какими-то фрагментарными документами, и я все еще наступаю на эти документы при развертывании многих ям.
Поэтому, основываясь на собственном успешном опыте развертывания, я написал этот документ.
Использование docker, естественно, требует среды docker.Конечно, доступ к образам docker в Китае относительно медленный.Рекомендуется использовать местные источники.
Сборка DockerFile
Наша работа основана на зеркалировании Mysql.
docker pull mysql:5.7.20
Эта команда загрузит последний образ mysql, конечно, вы также можете указать версию.
Создайте новый файл DockerFile:
FROM mysql:5.7.20
EXPOSE 3306
COPY my.cnf /etc/mysql/
CMD ["mysqld"]
Перед сборкой образа нам нужен файл конфигурации mysql my.cnf , вы можете сначала запустить контейнер mysql, затем войти в контейнер, чтобы скопировать его, и изменить его:
!includedir /etc/mysql/conf.d/
[mysqld]
pid-file=/var/run/mysqld/mysqld.pid
socket=/var/run/mysqld/mysqld.sock
datadir=/var/lib/mysql
#log-error=/var/log/mysql/error.log
# By default we only accept connections from localhost
#bind-address = 127.0.0.1
log-bin=/var/log/mysql/mysql-bin.index
server-id=1
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
Вышеупомянутый файл my.conf, который я изменил, мы в основном изменяем следующие параметры:
#bind-address = 127.0.0.1 # 注释这个选项可以让远程机器访问,或者可以修改为 0.0.0.0
log-bin=/var/log/mysql/mysql-bin.index # 开启 log-bin 日志,日志路径
server-id=1 # 服务器唯一ID,默认是1,一般取IP最后一段,这里看情况分配
Это моя основная библиотекаmy.cnf
, в принципе то же самое из библиотеки, толькоservier-id
Не то же самое, раб библиотека 2, и этот файл тоже лежит в папке.
Структура файла, необходимая для сборки, выглядит следующим образом:
master
├── Dockerfile
└── my.cnf
slave
├── Dockerfile
└── my.cnf
Затем в главном каталоге используйтеdocker build -t master/mysql:5.7.20 .
Команда создает главную библиотеку зеркала, а вспомогательная библиотека создает командуdocker build -t slave/mysql:5.7.20 .
. В конце команды есть.
, не забывайте, представляет текущий каталог. -t означает тег, который является аббревиатурой --tag, обозначающей имя образа. Если докер не добавлен, образу будет присвоено случайное имя. Рекомендуемый формат:name:tag
Настроить докер-контейнер
После завершения сборки мы запускаем основную и подчиненную библиотеки следующими командами:
docker run -p 3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=root -d master/mysql:5.7.20
docker run -p 3306 --name mysql-slave --link mysql-master:master -e MYSQL_ROOT_PASSWORD=root -d slave/mysql:5.7.20
а затем выполнитьdocker exec -it mysql-master bash
иdocker exec -it slave-master bash
Команда идет внутри контейнера. воплощать в жизньmysql -uroot -proot
Войдите в среду mysql.На данный момент построение нашей среды завершено.Ниже приведена формальная конфигурация соединения master-slave.
Конечно, в это время docker назначит контейнеру уникальный порт, и мы также можем настроить его с помощью подключения клиента mysql. использоватьdocker ps
Просмотрите номер порта, вы можете использовать клиентское соединение для управления.
☁ mysql-master-slave docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
6c7648e829e0 slave/mysql:5.7.20 "docker-entrypoint..." 4 minutes ago Up 4 minutes 0.0.0.0:32769->3306/tcp mysql-slave
483842c63235 master/mysql:5.7.20 "docker-entrypoint..." 5 minutes ago Up 5 minutes 0.0.0.0:32768->3306/tcp mysql-master
использоватьGRANT REPLICATION SLAVE ON *.* to 'user'@'%' identified by 'mysql';
илиGRANT REPLICATION SLAVE ON *.* TO 'user'@'192.168.1.200' IDENTIFIED BY 'mysql';
Создайте пользователя, к предыдущему доступ по всем ips, а к следующему доступ только по указанию ip.
затем используйтеGRANT SELECT,REPLICATION SLAVE ON *.* TO 'user'@'%';
Дайте этому пользователю разрешение на чтение.
использоватьshow master status
Проверьте состояние основного контейнера mysql и напечатайте следующую информацию:
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000003 | 154 | | | |
+------------------+----------+--------------+------------------+-------------------+
использоватьhostname
Просмотрите имя хоста основного контейнера, например, мой основной контейнер483842c63235
.
Затем настройте подчиненную библиотеку mysql:
change master to
master_host='master',#要连接的主服务器的ip
master_user='user',#指定的用户名,最好不要用root
master_log_file='mysql-bin.000003',#主库记录的值
master_log_pos=154,#主库的pos值
master_port=3306,#主库3306映射的端口
master_password='mysql';#主库要连接的用户的密码了
использоватьstart slave
Начать синхронизацию master-slave
Посмотреть с помощью командыshow slave status\G
Распечатайте следующую информацию:
*************************** 1. row ***************************
Slave_IO_State: Connecting to master
Master_Host: master //主服务器地址
Master_User: user //授权帐户名,尽量避免使用root
Master_Port: 3306 //数据库端口,部分版本没有此行
Connect_Retry: 60
Master_Log_File: mysql-bin.000003 //同步主库的日志文件名
Read_Master_Log_Pos: 154 //同步读取二进制日志的位置,大于等于
Relay_Log_File: 6c7648e829e0-relay-bin.000001
Relay_Log_Pos: 4
Relay_Master_Log_File: mysql-bin.000003
Slave_IO_Running: Yes //此状态必须YES
Slave_SQL_Running: Yes //此状态必须YES
Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 154
Relay_Log_Space: 154
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: NULL
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
Replicate_Ignore_Server_Ids:
Master_Server_Id: 0
Master_UUID:
Master_Info_File: /var/lib/mysql/master.info
SQL_Delay: 0
SQL_Remaining_Delay: NULL
Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
Master_Retry_Count: 86400
Master_Bind:
Last_IO_Error_Timestamp:
Last_SQL_Error_Timestamp:
Master_SSL_Crl:
Master_SSL_Crlpath:
Retrieved_Gtid_Set:
Executed_Gtid_Set:
Auto_Position: 0
Replicate_Rewrite_DB:
Channel_Name:
Master_TLS_Version:
1 row in set (0.00 sec)
На этом настройка набора master-slave mysql завершена.
сценарий оболочки
Соответствующий сценарий оболочки может запустить группу контейнеров master-slave mysql за 1 минуту.Выполнение этого сценария требует небольшой модификации, в основном файла конфигурации mysql.
#!/bin/bash
MASTER_DIR=/var/lib/mysql/mysql-master
SLAVE_DIR=/var/lib/mysql/mysql-slave
## First we could rm the existed container
docker rm -f mysql-master
docker rm -f mysql-slave
## Rm the existed directory
rm -rf $MASTER_DIR
rm -rf $SLAVE_DIR
## Start instance
docker run -p 3306 --name mysql-master -v /etc/master.cnf:/etc/mysql/my.cnf -v $MASTER_DIR:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d master/mysql:5.7.20
docker run -p 3306 --name mysql-slave -v /etc/slave.cnf:/etc/mysql/my.cnf -v $MASTER_DIR:/var/lib/mysql --link mysql-master:master -e MYSQL_ROOT_PASSWORD=root -d slave/mysql:5.7.20
## Creating a User for Replication
docker stop mysql-master mysql-slave
docker start mysql-master mysql-slave
sleep 3
docker exec -it mysql-master mysql -S /var/lib/mysql/mysql.sock -e "CREATE USER 'users'@'127.0.0.1' IDENTIFIED BY 'mysql';GRANT REPLICATION SLAVE ON *.* TO 'users'@'127.0.0.1';"
## Obtaining the Replication Master Binary Log Coordinates
master_status=`docker exec -it master mysql -S /var/lib/mysql/mysql.sock -e "show master status\G"`
master_log_file=`echo "$master_status" | awk 'NR==2{print substr($2,1,length($2)-1)}'`
master_log_pos=`echo "$master_status" | awk 'NR==3{print $2}'`
master_log_file="'""$master_log_file""'"
## Setting Up Replication Slaves
docker exec -it mysql-slave mysql -S /var/lib/mysql/mysql.sock -e "CHANGE MASTER TO MASTER_HOST='master',MASTER_PORT=3306,MASTER_USER='users',MASTER_PASSWORD='mysql',MASTER_LOG_FILE=$master_log_file,MASTER_LOG_POS=$master_log_pos;"
docker exec -it mysql-slave mysql -S /var/lib/mysql/mysql.sock -e "start slave;"
docker exec -it mysql-slave mysql -S /var/lib/mysql/mysql.sock -e "show slave status\G"
## Creates shortcuts
grep "alias mysql-master" /etc/profile
if [ $? -eq 1 ];then
echo 'alias mysql="docker exec -it mysql-master mysql"' >> /etc/profile
echo 'alias master="docker exec -it mysql-master mysql -h 127.0.0.1 -P3306"' >> /etc/profile
echo 'alias slave="docker exec -it mysql-master mysql -h 127.0.0.1 -P3307"' >> /etc/profile
source /etc/profile
fi