共计 1653 个字符,预计需要花费 5 分钟才能阅读完成。
准备
- 主从数据库版本最好一致
- 主从数据库内数据保持一致
- 主数据库:192.168.1.31 /linux
- 从数据库:192.168.1.32 /linux
在主数据库上的操作
找到配置文件,并修改它,找到[mysqld]
log-bin=mysql-bin #开启二进制日志
server-id=31 #设置server-id
重启MySQL,创建同步账号
先登录到主MySQL
mysql -uroot -p123
创建同步账号,192.168.% 的意思是授权全部内网访问
mysql> CREATE USER 'repl'@'192.168.%' IDENTIFIED BY 'slavepass';#创建用户
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.%';#分配权限
mysql>flush privileges; #刷新权限
查看master状态,记录二进制文件名(mysql-bin.000003)和位置(73)
mysql > SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000003 | 73 | test | manual,mysql |
+------------------+----------+--------------+------------------+
设置不同步哪些数据库
# 修改MySQL配置文件
[mysqld]下
# 不同步哪些数据库
binlog-ignore-db = mysql
binlog-ignore-db = test
binlog-ignore-db = information_schema
# 只同步哪些数据库,除此之外,其他不同步
binlog-do-db = game
修改完之后重启MySQL
在从数据库上的操作
修改mysql配置
[mysqld]
server-id=32 #设置server-id,必须唯一
重启mysql,打开mysql会话,执行同步SQL语句(需要主服务器主机名,登陆凭据,二进制文件的名称和位置)
CHANGE MASTER TO MASTER_HOST='192.168.1.31', MASTER_USER='repl', MASTER_PASSWORD='slavepass', MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS=73;
启动slave同步进程
mysql>start slave;
查看slave状态
mysql> show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.1.31
Master_User: rep1
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000013
Read_Master_Log_Pos: 11662
Relay_Log_File: mysqld-relay-bin.000022
Relay_Log_Pos: 11765
Relay_Master_Log_File: mysql-bin.000013
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
...
当Slave_IO_Running和Slave_SQL_Running都为YES的时候就表示主从同步设置成功了。
正文完