(1) master 将数据改变记录到二进制日志(binary log)中,也即是配置文件log-bin 指定的文件(这些记录叫做二进制日志事件,binary log events)
(2) slave 将 master 的 binary log events 拷贝到它的中继日志(relay log)
(3) slave 重做中继日志中的事件,将改变反映它自己的数据(数据重演)
- 在已经安装好两台及以上mysql单体服务的前提下,修改/etc/my.cnf配置文件,server-id值必须不同,主从添加配置如下:
[mysqld]
server-id=1
log-bin=mysql-bin
- 配置好主从后分别重启主从mysql
service mysqld restart
- 进入主mysql中创建slave用户,并授权
mysql -u root -p
create user 'slave01'@'192.168.0.2' identified by 'slavepass';
grant replication slave on *.* to 'slave01'@'192.168.0.2' identified by 'slavepass';
flush privileges;
show master status;
- 进入从mysql,连接主mysql, 然后对应其中连接的主mysql创建的用户slave01,master_log_file和master_log_pos的值,如下:
mysql -u root -p
change master to master_host='192.168.0.1',master_user='slave01',master_password='slavepass',master_port=3306,master_log_file='mysql-bin.000005',master_log_pos=154;
start slave;
- 查看从msyql的连接状态,其中要查看主服务信息是否一致,以及Slave_IO_Running和Slave_SQL_Running要都为Yes
show slave status\G;
- Slave_IO_Running和Slave_SQL_Running要不为Yes,查看最后错误情况Last_SQL_Error,找出问题
7. 创建对应的主从数据库和表结构,在主数据库某表插入数据,然后从从数据库查看是否有相应数据