1.主mysql服务更改配置文件修改
vi /etc/my.cnf
1.1 新增服务唯一ID ,并开启二进制日志。
[mysqld] ## 同一局域网内注意要唯一 server-id=100 ## 开启二进制日志功能,可以随便取(关键) log-bin=mysql-bin ## 需要同步的数据库 binlog_do_db = video ## 不需要同步的数据库 binlog_ignore_db = mysql
修改完配置之后需要重启
service mysqld restart
重启之后进入mysql创建从服务器用户
mysql -uroot -p # 创建从用户 CREATE USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY 'ba@dehg6hkk'; # 授予用户 slave REPLICATION SLAVE权限和REPLICATION CLIENT权限,用于在主从库之间同步数据。 GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
查看主sql状态
show master status; # 记录下File和Position的值,并且不进行其他操作以免引起Position的变化。
2.从服务器配置
vi /etc/my.cnf
## 设置server_id,注意要唯一 server-id=101 ## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用 log-bin=mysql-slave-bin ## relay_log配置中继日志 relay_log=edu-mysql-relay-bin
修改完配置之后需要重启
service mysqld restart
重启之后进入mysql
mysql -uroot -p # 设置主服务器 change master to master_host='172.17.0.2', master_user='slave', master_password='ba@dehg6hkk', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos= 2830,master_connect_retry=30;
master_host :Master的地址
master_port:Master的端口号
master_user:用于数据同步的用户
master_password:用于同步的用户的密码
master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒
在从mysql中查看主从同步状态:
show slave status \G;
此时的SlaveIORunning 和 SlaveSQLRunning 都是No,因为我们还没有开启主从复制过程。
开启主从复制:
start slave;
再次查看同步状态:
show slave status \G;
SlaveIORunning 和 SlaveSQLRunning 都是Yes说明主从复制已经开启。
若SlaveIORunning一直是Connecting,有下面4种原因:
1、网络不通,检查ip端口
2、密码不对,检查用于同步的用户名和密码
3、pos不对,检查Master的Position
4、mysql8特有的密码规则问题引起:
ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '@#$Rfg345634523rft4fa';
将密码规则修改为:mysql_native_password
如果需要指定想要主从同步哪个数据库,可以在master的my.cnf
添加配置:
binlog-do-db:指定mysql的binlog日志记录哪个db
或者在slave的my.cnf
添加配置:
replicate-do-db=需要复制的数据库名,如果复制多个数据库,重复设置这个选项即可
replicate-ignore-db=需要忽略复制的数据库名,如果忽略复制多个数据库,重复设置这个选项即可
如果想要同步所有库和表,在从mysql执行:
STOP SLAVE SQL_THREAD;
CHANGE REPLICATION FILTER REPLICATE_DO_DB = ();
start SLAVE SQL_THREAD;
如果以上步骤出现问题,可以查看日志:
/etc/log/mysqld.log
修改同步速度
show variables like '%slave_parallel%'
stop slave;
SET GLOBAL slave_parallel_type='LOGICAL_CLOCK';
SET GLOBAL slave_parallel_workers=8;
start slave;