mysql主从复制(亲测能打)

1 安装mysql不说了,具体参照:linux下mysql5.7.22数据库解压版安装_王林冲的博客-CSDN博客

1、主从服务器分别作以下操作
  1.1、版本一致
 

2、修改主服务器master:
   #vi /etc/my.cnf
      

#在[mysqld]新增bin_log配置

[mysqld]


#开启bin_log 启用二进制日志
log-bin=mysql-bin

#服务器唯一ID,默认是1,一般取IP最后一段
server-id=119

binlog_format=ROW

3、修改从服务器slave:
   #vi /etc/my.cnf

#在[mysqld]新增bin_log配置

[mysqld]


#开启bin_log 启用二进制日志
log-bin=mysql-bin

#服务器唯一ID,默认是1,一般取IP最后一段
server-id=119

binlog_format=ROW

分别重启master和slave服务器的mysql:

service mysqld restart

5、在主服务器上建立帐户并授权slave:

bin/mysql -u root -p

Enter password: 输入你的密码

#创建SLAV账户,账户名:myslave,密码:123456,真实场景的密码可以设置复杂点
mysql> GRANT REPLICATION SLAVE ON *.* to 'myslave'@'%' identified by '123456';
Query OK, 0 rows affected, 1 warning (0.03 sec)

#查看master的状态
mysql> show master status;

+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000003 |      433 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

解释:File = mysql-bin.000003, Position = 433,这两个参数要在slave监听是要配置的,
即slave服务器监听master的bin_log文件是mysql-bin.000003,位置是 433


 

7、配置从服务器Slave:

bin/mysql -u root -p

Enter password: 输入你的密码

修改slave里的mysql服务器的主节点master为

mysql> change master to master_host='master的mysql所在服务器ip',
master_user='wlcslave',master_password='123456',
 master_log_file='mysql-bin.000003',master_log_pos=433;


# 启动从服务器复制功能

mysql>start slave; 

#检查从服务器复制功能状态
mysql> show slave status\G;
mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.0.252
                  Master_User: wlcslave
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000003
          Read_Master_Log_Pos: 433
               Relay_Log_File: hecs-x-xlarge-2-linux-20201228133635-relay-bin.000002
                Relay_Log_Pos: 320
        Relay_Master_Log_File: mysql-bin.000003
             Slave_IO_Running: Yes      #必须为yes
             Slave_SQL_Running: Yes     #必须为yes

        ...............................................................

然后你可以在navicat连接master的mysql,创建一个数据库,在搞几张表,搞点数据

然后你就会在你的slave的mysql服务器上看到master上mysql的数据库,表,即同步成功

注意:master以前的数据库数据不会同步过来,可以先备份,把这些数据库删除,在建个一样的数据库,数据搞进去,走一遍创建数据库和插入数据的流程,就会同步到slave数据库中,缺点就是主库不能写入数据,

另一种方案则是: 让从库从第一个binlog文件开始重放: 只需将上述步骤四中的命令改为

先查看有多少个bin_log文件,命令:

show binary logs;

show master logs;

这两个命令任何一个都可以

 然后一个个手动同步过来

mysql> stop slave; #先停止slava同步


change master to master_host='master的mysql所在服务器ip',
master_user='wlcslave',master_password='123456',
master_log_file='mysql-bin.000001',master_log_pos=0;


change master to master_host='master的mysql所在服务器ip',
master_user='wlcslave',master_password='123456',
master_log_file='mysql-bin.000002',master_log_pos=0;


等

在启动slave同步
mysql> start slave;

编写一shell脚本,用nagios监控slave的两个yes(Slave_IO及Slave_SQL进程),如发现只有一个或零个yes,就表明主从有问题了,发短信警报吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

IT学习道场

为你的进步加点油!

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

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

打赏作者

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

抵扣说明:

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

余额充值