docker 安装运行mysql数据库(主从)

18 篇文章 0 订阅
9 篇文章 0 订阅

利用 docker 实现 mysql 主从同步 / 读写分离

为了保证数据的完整和安全,mysql 设计了主从同步,一个挂掉还可以用另个

通过本文实际你会操作到。

  1. mysql 的主从同步
  2. docker 镜像和容器的创建
  3. docker 容器间的数据传递
  4. mycat 入门

centos:7  + mysql:5.7

1、拉取数据库镜像

docker pull mysql:5.7

 2、利用mysql镜像,创建用于主从同步的两个新镜像

我们当前所在的服务器叫宿主服务器

我们要利用 docker 虚拟两个 docker 容器服务器,一个主服务器,一个从服务器。

3、创建主、从数据库的数据目录

#主库目录
mkdir -p /data/docker/mysql-master
mkdir -p /data/docker/mysql-master/log
mkdir -p /data/docker/mysql-master/data
mkdir -p /data/docker/mysql-master/conf

#从库目录
mkdir -p /data/docker/mysql-slave
mkdir -p /data/docker/mysql-slave/log
mkdir -p /data/docker/mysql-slave/data
mkdir -p /data/docker/mysql-slave/conf

4、在 master/conf 文件夹下 创建 my.cnf 内容为

[mysqld]
#[必须]启用二进制日志
log-bin=mysql-bin  
#[必须]服务器唯一ID,默认是1,一般取IP最后一段,这里看情况分配
server-id=1
# 指定不需要同步的数据库名称
binlog-ignore-db=mysql  
# 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
# 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
# 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
# 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
# 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062  

5、在 slave/conf 文件夹下 创建 my.cnf 内容为

[mysqld]
#[必须]启用二进制日志,以备Slave作为其它数据库实例的Master时使用
log-bin=mysql-slave1-bin     
#[必须]服务器唯一ID,默认是1,一般取IP最后一段,这里看情况分配                             
server-id=2
# 指定不需要同步的数据库名称
binlog-ignore-db=mysql   
# 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
# 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
# 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
# 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
# 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062  
# relay_log配置中继日志
relay_log=mall-mysql-relay-bin  
# log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1  
# slave设置为只读(具有super权限的用户除外)
read_only=1  

 6、用镜像创建容器

         docker 默认容器间网络不通,故先创建网络
(1)默认网络列表

docker network ls

 
         红色标注的为自建网络,

 (2)创建脚本如下,默认桥接

docker network create mysql_network

 (3)启动容器时,指定同一网络,即可实现容器间网络通信

增加启动参数 --network <name>

docker run -di --name mysql-master-1  --network mysql_network  -p 33061:3306  -v /data/docker/mysql-master/log:/var/log/mysql -v /data/docker/mysql-master/data:/var/lib/mysql -v /data/docker/mysql-master/conf:/etc/mysql -e MYSQL_ROOT_PASSWORD=123456  mysql:5.7



docker run -di --name mysql-slave-1  --network mysql_network -p 33062:3306 -v /data/docker/mysql-slave/log:/var/log/mysql -v /data/docker/mysql-salve/data:/var/lib/mysql -v /data/docker/mysql-slave/conf:/etc/mysql -e MYSQL_ROOT_PASSWORD=123456  mysql:5.7

测试连接,启动成功后,开始配置主从同步

mysql 主从配置

1、在主容器 mysql 中输入以下命令:


mysql>GRANT REPLICATION SLAVE ON *.* TO 'user'@'192.168.100.139' IDENTIFIED BY '123456';(指定ip)
或者
mysql>GRANT REPLICATION SLAVE ON *.* to 'user'@'%' identified by '123456';(所有ip)

mysql>SHOW MASTER STATUS;

查看状态

记录 File 的值和 Position 的值。

下面要用到,到这里为止,主库千万不要再做任何操作,防止状态改变。

12、然后我们配置一下从库

查看 master/mysql 的对外端口号

 0.0.0.0:33061->3306/tcp 其中 33061为 master 的端口
执行脚本
 

change master to
master_host='192.168.100.139',
master_user='user',
master_log_file='mysql-bin.000003',
master_log_pos=434,
master_port=33061,
master_password='123456';

start slave;

master_host=’x.x.x.x’ // 这里填 master 主机 ip

master_log_file=’mysql-bin.000003’, // 这里填写 File 的值

master_log_pos=1338,// 这里填写 Position 的值。

mysql> start slave;// 启动从服务器复制功能

如果不小心配置错, 输入 mysql> stop slave; 然后重新录入一遍

change master to
master_host='192.168.100.139',
master_user='user',
master_log_file='mysql-bin.000003',
master_log_pos=434,
master_port=33061,
master_password='123456';
start slave;    启动从库

STOP slave;   停止从库

reset slave;  重置从库

show slave status \G;   检查从库状态

13、检查主从连接状态

mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: x.x.x.x
                  Master_User: user
                  Master_Port: 32768
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000003
          Read_Master_Log_Pos: 1338
               Relay_Log_File: 8d1e3b87d499-relay-bin.000002
                Relay_Log_Pos: 1221
        Relay_Master_Log_File: mysql-bin.000003
             Slave_IO_Running: Yes
            Slave_SQL_Running: 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: 1338
              Relay_Log_Space: 1435
              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: 0
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: 1
                  Master_UUID: cd327a00-5e18-11e7-98f7-0242ac110006
             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)

这两个必须是 Yes 为 No 或者 connect 说明没有连接上

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

14、测试主从连接

注意设置主从后,操作只能在 master 终端上,slave 上的操作不会同步到 master 上。

15、登陆 master 终端

create database database_test;

mysql> create database database_test;
Query OK, 1 row affected (0.01 sec)
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| database_test|
| sys                |
+--------------------+
5 rows in set (0.00 sec)
mysql> use database_test
Database changed
mysql>  create table sunhao(id int(3),name char(10));
Query OK, 0 rows affected (0.04 sec)
mysql> insert into sunhao values(1,'xiaoshuai');
Query OK, 1 row affected (0.01 sec)
mysql> select * from sunhao;
+------+-----------+
| id   | name      |
+------+-----------+
|    1 | xiaoshuai |
+------+-----------+
1 row in set (0.00 sec)

16、登陆 slave 服务器

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| database_test|
| sys                |
+--------------------+
5 rows in set (0.00 sec)
mysql> use database_test
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from sunhao;
+------+-----------+
| id   | name      |
+------+-----------+
|    1 | xiaoshuai |
+------+-----------+

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

流浪书生gzs

原创不易,感谢支持打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值