mysql5.5主从同步配置文件_MySQL 5.5主从同步设置教程

本文详细介绍了如何配置MySQL主从复制,包括在Master和Slave服务器上修改my.cnf配置,设置binlog,创建复制用户,以及处理同步过程中可能出现的问题。此外,还提到了时间同步的重要性,通过ntpdate和yum安装NTP服务来确保服务器时间一致,以保证数据同步的准确性。
摘要由CSDN通过智能技术生成

先修改Master(10.1.123.197)的 my.cnf 配置

在[mysqld]中新增以下内容log-bin=mysql-binlog-bin-index=mysql-bin.indexserver-id = 1sync_binlog=1binlog_format=mixed

然后指定要做同步的数据库,并忽略掉不需要做同步的数据库

binlog-do-db =testdb

binlog-ignore-db =mysql

binlog-ignore-db =performance_schema

binlog-ignore-db =information_schema

在[mysqldump]中修改内容为

max_allowed_packet=32M

注意:确保 max_allowed_packet 有比较大的值,比如 max_allowed_packet=100M

重启 mysql

service mysql restart

在Master上创建一个复制用户CREATE USERfunsion;GRANT REPLICATION SLAVE ON *.* TO funsion IDENTIFIED BY 'ifunsion.com';

# 测试环境密码是 xyzzy+ ---------------------------------------------------------- +

再修改 Slave(10.1.123.160)的配置,修改 my.cnf

在[mysqld]中新增以下内容

server-id=2

log-bin = mysql-bin

relay-log-index = slave-relay-bin.indexrelay-log = slave-relay-bin

sync_master_info= 1sync_relay_log= 1sync_relay_log_info= 1# 以上三行话只使用于MySQL5.5输入 mysql-u root -p

进入mysql命令行,输入

CHANGE MASTERTO MASTER_HOST = '10.1.123.233', MASTER_USER = 'funsion', MASTER_PORT = 3306, MASTER_PASSWORD = 'ifunsion.com';

CHANGE MASTERTO MASTER_CONNECT_RETRY=30;

在输入 START SLAVE;+ ----------------------- 如果发生错误无法启动 ------------------- +

进入Master 的数据库

输入 show master status\G

记录下当前使用的log-bin文件,以及position (比如现在日志是 mysql-bin.000001 ,位置是 107)

然后进入Slave 的数据库

输入 stop slave;

change masterto master_log_file='mysql-bin.000001',master_log_pos=107;

最后输入 start slave;

最后在服务器上执行

yum-y install ntpdate

ntpdate cn.pool.ntp.org

clock-w

把几台服务器的时间同步+ ---------------------------- 一些可能用到的命令 ------------------------- +

执行锁表:

flush tableswith readlock;

这一步的目的是使我们在制作主从的过程中,主库中不会有新的数据,否则会给我们的同步设置带来麻烦

主库执行解锁:

unlock tables;

reset master 命令删除了所有的二进制日志文件并清空了二进制日志索引文件。

reset slave 命令删除了Slave复制所用的所有文件,重新开始。+ ----------------------- 其它参考文档(未验证)-------------------------- +

库业务不能停的情况下为从库制作镜像:

案例:

服务器1号:主

服务器2号:从

现在由于负载问题需要上架服务器3号同样为1号的从服务器。

但是1号库不能停,2号也不能停,主从同步进程也不能停(要求苛刻)。

可以这样做:

在主:

mysqldump-uroot -pxxxx -h127.0.0.1 --databases db1 db2 db3 --master-data=1 > bak.sql

3号服务器slave stop;

之后将bak.sql导入3号从服务器

slave start;

3号服务器会自动从导出的那一刻的节点更新。

因为--master-data=1 这个参数在导出sql文件后会在最下方加上change语句。如果--master-data=0,则不会带有。

非常的方便,但仅适合库不是太大的情况,该案例导出的库一共6G。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值