安装环境
操作系统 :CentOS 7.5 数据库版本:MySQL 5.7.22 主机A:222.222.0.61 (Master) 主机B:222.222.0.62
(Slave)
基本环境配置
开放数据库端口 确保两台机器在同一个局域网
Master的配置

在Linux环境下MySQL的配置文件的位置是在 /etc/my.cnf ,在该文件下[mysqld]中指定Master的配置如下:
log-bin=mysql-bin server-id=61 binlog-ignore-db=information_schema
binlog-ignore-db=mysql binlog-do-db=mstest
server-id:用于标识唯一的数据库,这里设置为61(与我自己的IP后面一段相同),在设置从库的时候就需要设置为其他值。
binlog-ignore-db:表示同步的时候ignore的数据库
binlog-do-db:指定需要同步的数据库
修改了配置文件重启MYSQL服务

进入mysql控制台:mysql -u root -p 回车,输入mysql密码进入

赋予从库权限帐号,允许用户在主库上读取日志,赋予222.222.0.62也就是Slave机器有File权限,只赋予Slave机器有File权限还不行,还要给它REPLICATION
SLAVE的权限才可以。
在Master数据库命令行中输入:
CREATE USER 'repl'@'222.222.0.%' IDENTIFIED BY 'repl'; GRANT REPLICATION SLAVE
ON *.* TO 'root'@'222.222.0.%' IDENTIFIED BY 'repl'; FLUSH PRIVILEGES;
这里使用的是 repl用户作为同步的时候使用到的用户,可以自己设定。

重启mysql,登录mysql,显示主库信息
show master status;
mysql>show master status;
+------------------+----------+--------------+--------------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+--------------------------+-------------------+
| mysql-bin.000005 | 5772 | mstest | information_schema,mysql | |
+------------------+----------+--------------+--------------------------+-------------------+
1 row in set (0.00 sec) mysql>
这里的 File
、Position是在配置Salve的时候要使用到的,Binlog_Do_DB表示要同步的数据库,Binlog_Ignore_DB表示Ignore的数据库,这些都是在配置的时候进行指定的。
注:如果执行这个步骤始终为Empty set(0.00 sec),那说明前面的my.cnf没配置对。

Slave的配置

1.从库的配置,也是修改配置文件:/etc/my.cnf 如下:
log-bin=mysql-bin server-id=62 binlog-ignore-db=information_schema
binlog-ignore-db=mysql replicate-do-db=mstest replicate-ignore-db=mysql
log-slave-updates slave-skip-errors=all slave-net-timeout=60
2.这里可以看到,在MySQL5.6之后的版本中没有指定:
master-host=222.222.0.61 #Master的主机IP master-user=root master-password=mysql
password #Master的MySQL密码

如果,你在MySQL5.6和之后的版本中配置从库的时候,设置到了上边的内容,即指定了master-host、master-user等信息的话,重启MySQL的时候就回报错,错误信息如下:
[root@mysql_2 ~]# service mysql restart
Shutting down MySQL.... SUCCESS!
Starting MySQL... ERROR! The server quit without updating PID file
(/data/mysql/mysql_2.pid).

此时,查看数据库的报错信息(数据库的目录, /data/mysql/mysql_2.err)(可能不一样,根据情况来),可以看到:
[ERROR] unknown variable 'master-host=222.222.0.62'
可以看出master-host 被检测数是一个未知的变量,因此会出现错误。

修改my.cnf,删除master-host等配置之后重启一下MySQL(service mysql restart)

进入Slave mysql控制台,执行:
stop slave; #关闭Slave change master to master_host='222.222.0.61',
master_password='root', master_log_file='mysql-bin.000005',
master_log_pos=5772; start slave; #开启Slave
#show master status;命令查看到的master mysql上的信息对应写入
#在这里指定Master的信息,
#master_log_file是在配置Master的时候的File选项
#master_log_pos是在配置Master的Position 选项,这里要进行对应。
然后可以通过mysql> show slave status 查看配置的信息: mysql> show slave status \G
*************************** 1. row *************************** Slave_IO_State:
Waiting for master to send event Master_Host: 222.222.0.61 Master_User: repl
Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin.000005
Read_Master_Log_Pos: 5772 Relay_Log_File: mysql_2-relay-bin.000002
Relay_Log_Pos: 2299 Relay_Master_Log_File: mysql-bin.000005 Slave_IO_Running:
Yes Slave_SQL_Running: Yes Replicate_Do_DB: mstest Replicate_Ignore_DB: mysql
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: 5772 Relay_Log_Space: 2508 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: f7a686bf-666d-11e8-802c-000c294df5c9
Master_Info_File: /data/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)
出现下面内容表示成功了:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

可以看到,已经配置成功。