一、确保主库从库网络畅通可互相访问

二、主库配置

1、编辑主库的my.cnf

   在[mysqld]下添加如下配置

   server-i=1 #一般默认为1,不需要修改(一般都以ip的后两位为server-id,保证全局的一致)

   read-only=0#主库读写都可以

   binlog-do-db=test#需要同步的数据库名称,要同步多个可以写多行

   binlog-ignore-db=mysql#不需要同步的数据库名称,可以写多行

   binlog-ignore-db=performance_schema

   log-bin=mysql-bin #二进制日志名称,确保此文件可写

2、设置同步数据库用的账号

service mysqld restart,登录,执行如下命令,意思是给slave节点195,配置登录用户,密码,权限,

用户:backup,密码:123,slave节点:10.6.222.195,权限:replication slave

  例:  grant replication slave on *.* to backup@10.6.222.195 identified by '123'

3、查看主机状态

mysql>show master status;

 

mysql在主库上执行语句后从库生效没 mysql主从库配置_主从配置

记下file和position ,这里显示的binlog_do_db和binlog_ignore_db就是第一步在配置文件中设置的。file是同步的日志文件,position应该是从文件第几行开始

三、从库配置

1、编辑从库的my.cnf

server-id改成与主库不一致,也可以添加replicate-do-db和replicate-ignore-db来指定同步的数据库和不同步的数据库。

   server-id=2

从库只读

   replicate-do-db=test

   replicate-ignore-db=mysql

   replicate-ignore-db=information_schema

   replicate-ignore-db=performance_schema

2、在从库上设置主库信息

mysql,在mysql中执行stop slave; 然后用change master 命令设置主库信息。

   mysql>change master to master_host='10.6.208.183',master_user='backup',master_password='123',master_log_file='mysql-bin.000019',master_log_pos=746;

master_host为主库ip;master_user,master_password是第二步分配的同步用的用户名和密码;master_log_file,master_log_position是第三步中的file和position值。

3、查看是否配置成功

start slave #启动从数据库

show slave status \G;#查看从库状态

 

mysql在主库上执行语句后从库生效没 mysql主从库配置_主从配置_02

若Slave_IO_State、Slave_IO_Running、Slave_SQL_Running状态如上图则表示配置成功。

四、其他

1、主从库都配置好后,将主库的进行一个完全备份,然后导入从库,保证当前主从一致,那么以后主库的任何修改都会同步到从库上面,保证主从数据的一致性。

2、配置过程常见错误

若出现Slave_IO_Running、Slave_SQL_Running状态为no,则从stop slave 从新执行一遍change master to master_host='10.6.208.183',master_user='backup',master_password='123',master_log_file='mysql-bin.000019',master_log_pos=746;

然后再start slave就可以了。