- 重启mysql,进入mysql,查看对应的server_id是否设置成功
- mysql> show variables like ‘server_id‘;
- +---------------+-------+
- | Variable_name | Value |
- +---------------+-------+
- | server_id | 1 |
- +---------------+-------+
- 1 row in set (0.00 sec)
- 表示设置是成功的
- 进入mysql,执行以下命令
- mysql> CREATE USER ‘lisi‘@‘%‘ IDENTIFIED BY ‘Lisi@123456‘;
- Query OK, 0 rows affected (0.00 sec)
- mysql> GRANT REPLICATION SLAVE ON . TO ‘lisi‘@‘%‘;
- Query OK, 0 rows affected (0.00 sec)
- 接下来通过FLUSH刷新所有表和块写入语句
- mysql> FLUSH TABLES WITH READ LOCK;
- Query OK, 0 rows affected (0.00 sec)
- 然后确定当前的二进制日志文件名称和位置:
- mysql> show master status;
- +------------------+----------+--------------+------------------+-------------------+
- | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
- +------------------+----------+--------------+------------------+-------------------+
- | mysql-bin.000005 | 802858 | | | |
- +------------------+----------+--------------+------------------+-------------------+
- 1 row in set (0.00 sec)
- mysql> CHANGE MASTER TO MASTER_HOST=‘192.168.1.2‘, MASTER_USER=‘lisi‘, MASTER_PASSWORD=‘Lisi@123456‘, MASTER_LOG_FILE=‘mysql-bin.000005‘,MASTER_LOG_POS=802858;
- 参数讲解
- MASTER_HOST master的ip地址
- MASTER_USER master的复制用户名
- MASTER_PASSWORD master的复制用户的密码
- MASTER_LOG_FILE master的二进制文件
- MASTER_LOG_POS master的二进制文件位置
- mysql> start slave;
- Query OK, 0 rows affected (0.00 sec)
- 查看slave状态
- mysql> show slave status\G
- 可以查看这两个是Yes那就说明成功了
- mysql> UNLOCK TABLES;
- Query OK, 0 rows affected (0.00 sec)
注意:
- 需要验证一下master的复制账号是否能远程登录
- 复制组中的每个服务器必须配置唯一的server ID
这次操作踩的坑:
- Q: Can‘t connect to MySQL server on ‘server’ 在当前主机上 mysql -uUserName -p -h localhost 可以连接上 mysql -uUserName -p -h ‘ip地址‘ 连接不上
- A:先按照https://dev.mysql.com/doc/refman/8.0/en/can-not-connect-to-server.html介绍的方法进行排查,最后还发现连接不上,如果是阿里云的服务器,那么可能就是防火墙把3306d端口给关了,那么就要在防火墙把这个端口给放开
- 或者进入https://help.aliyun.com/document_detail/25471.html?spm=a2c4e.11153987.0.0.2de65a75vopCz7进行设置
- Q:在slave机器上mysql -uUserName -p -h ‘master的ip地址’ 可以连接上,但show slave status是下图
- A:查看错误日志
- 2026是ssl错误,说明我们启动了ssl连接
- 这时候需要在master和slave上的my.conf文件加上以下行
- 然后重启mysql,如果在mysql中看到以下结果,就说明ssl被关闭了
- 这时候如果slave还是连接不上master的话,我们再看一下show slave status的信息
- 如果Master_SSL_Allowed为Yes,那么就要改为No,具体修改在change master语句里面改,本次我们的修改例子为
CHANGE MASTER TO MASTER_HOST=‘192.168.1.2‘, MASTER_USER=‘lisi‘, MASTER_PASSWORD=‘Lisi@123456‘, MASTER_LOG_FILE=‘mysql-bin.000005‘,MASTER_LOG_POS=802858,master_ssl=0; 主要是master_ssl=0然后在执行一下start slave。
原文地址:http://blog.51cto.com/itzhoujun/2351367
时间: 2024-10-03 13:38:45