如何配置两个MySQL数据库之间的主从同步功能?

如何配置两个MySQL数据库之间的主从同步功能?,第1张

IP的设置:A主机 IP:10.10.0.119;Mask:255.255.0.0;B主机 IP:10.10.8.112;Mask:255.255.0.0

在IP设置完成以后,需要确定两主机的防火墙确实已经关闭。可以使用命令service iptables status查看防火墙状态。如果防火墙状态。

为仍在运行。使用service iptables stop来停用防火墙。如果想启动关闭防火墙,可以使用setup命令来禁用或定制。最终以两台主机可以相互ping通为佳。

3.2 配置A主(master) B从(slave)模式;3.2.1 配置A 为master。

增加一个用户同步使用的帐号:

GRANT FILE ON *.* TO ‘backup’@'10.10.8.112' IDENTIFIED BY ‘1234’

GRANTREPLICATION SLAVE ON *.* TO ‘backup’@'10.10.8.112' IDENTIFIED BY ‘1234’。

赋予10.10.8.112也就是Slave机器有File权限,只赋予Slave机器有File权限还不行,还要给它REPLICATION SLAVE的权限才可以。

增加一个数据库作为同步数据库:create database test

创建一个表结构:create table mytest (username varchar(20),password varchar(20))

修改配置文件:修改A的/etc/my.cnf文件。

在my.cnf配置项中加入下面配置:

server-id = 1 #Server标识

log-bin

binlog-do-db=test #指定需要日志的数据库

重起数据库服务:

service mysqld restart

查看server-id:

show variable like ‘server_id’。

在[mysqld]配置段添加如下字段

使用master状态

show master status记录file和position的值

在[mysqld]配置段添加如下字段,

连接slave,在mysql命令行执行以下命令,设置参数,启动slave

MASTER_LOG_FILE 对应master的status的file

MASTER_LOG_POS 对应master的status的position

主要查看Slave_IO_Running和Slave_SQL_Running 两列是否都为YES

就这个问题可以比较负责任的说明如下:

1、网上参考的资料中存在一定的误解部分主要是mysql的各个版本中对于同步master slave的 *** 作方式和参数有一定的出入; 所以在这个问题上面要首先说明的是msyql的版本;

之前mysql 有6.0的版本测试 ,其中的配置方式就与mysql 5的存在一定的不同参数,这些参数在mysql的网站的手册文档中是有的,具体是那个url 有些遗忘了,不过应该是可以找到的

2、就是配置mysql的复制建议在my.cnf中配置好对应的参数信息,然后通过mysql的服务启动进行自动的复制 减少过多的手动 *** 作部分,手动的部分就是排错的过程;

3、如果是多节点 那么建议考虑master的heartbeat的模式,因为slave到master是需要手动的切换 除非是另外的一种master master的模式


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7338097.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-04
下一篇 2023-04-04

发表评论

登录后才能评论

评论列表(0条)

保存