且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

MySQL数据库主从复制

更新时间:2022-10-04 09:39:10

主从复制数据库注意时间要同步:

1
ntpdate 172.18.0.1 #以本局域网的某一主机作为时钟服务器

主服务器:

1
2
3
4
5
6
vim /etc/my.cnf.d/server.cnf 
[server]
  skip_name_resolve=ON      //忽略名称解析
  innodb_file_per_table=ON  //每个存储表占用一个单独文件
  server_id = 1             //服务id,必须存在
  log_bin = msater-bin      //二进制日志,本处是相对路径,相对于/var/lib/mysql

启动mariadb.service服务

1
2
3
4
5
6
7
8
GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO 'repluser'@'192.168.1.%' IDENTIFIED BY 'centos'
//授权从服务的复制用户
//REPLICATION SLAVE 常用于建立复制时所需要用到的用户权限
//REPLICATION CLIENT 不可用于建立复制,有该权限时,只是多了可以使用如"SHOW SLAVE STATUS""SHOW MASTER STATUS"等命令。
FLUSH PRIVILEGES;
//写入磁盘
SHOW MASTER STATUS;
//查看二进制日志状态


从服务器:

1
2
3
4
5
6
7
vim /etc/my.cnf.d/server.cnf 
[server] 
  skip_name_resolve = ON 
  innodb_file_per_table = ON  
  server_id = 2   
  relay_log = relay-log  //中继日志用于存放从主服务器上读取的二进制内容
  read_only=ON          //从服务器只读不能写入

启动mariadb.service服务

1
2
3
4
5
6
CHANGE MASTER TO MASTER_HOST='192.168.1.101',MASTER_USER='repluser',MASTER_PASSWORD='centos',MASTER_LOG_FILE='master-log.000003',MASTER_LOG_POS=495;
//连接到主服务器的授权账户,并从指定二进制日志位置开始复制
START SLAVE IO_THREAD,SQL_THREAD;
//开启从节点的IO和SQL进程,前者是从主服务器复制时的IO操作,后者是从服务器本身进行的SQL操作
SHOW SLAVE STATUS\G;
//最后查看从服务的状态,各个参数都能从字面意思得到解释,不再赘述


测试:

此时在主服务器上创建一个数据库或者表,然后在从服务器上查看,是能够看到新创建的库或者表,虽然从本身并未创建任何东西;

至此主从复制完成


本文转自  a_pan  51CTO博客,原文链接:http://blog.51cto.com/panpangao/1981418