MySQL 5.5主从同步设置笔记分享
数据库  /  管理员 发布于 6年前   204
先修改Master(10.1.123.197)的 my.cnf 配置
在 [mysqld] 中新增以下内容:
复制代码 代码如下:
log-bin=mysql-bin
log-bin-index=mysql-bin.index
server-id = 1
sync_binlog=1
binlog_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 USER funsion;
GRANT REPLICATION SLAVE ON *.* TO funsion IDENTIFIED BY '.net.cn';
# 测试环境密码是 xyzzy
+ ---------------------------------------------------------- +
再修改 Slave(10.1.123.160)的配置,修改 my.cnf
在 [mysqld] 中新增以下内容
复制代码 代码如下:
server-id=2
log-bin = mysql-bin
relay-log-index = slave-relay-bin.index
relay-log = slave-relay-bin
sync_master_info = 1
sync_relay_log = 1
sync_relay_log_info = 1
# 以上三行话只使用于MySQL 5.5
输入 mysql -u root -p
进入mysql命令行,输入
复制代码 代码如下:
CHANGE MASTER TO MASTER_HOST = '10.1.123.233', MASTER_USER = 'funsion', MASTER_PORT = 3306, MASTER_PASSWORD = 'ifunsion.com';
CHANGE MASTER TO MASTER_CONNECT_RETRY=30;
在输入 START SLAVE;
+ ----------------------- 如果发生错误无法启动 ------------------- +
进入Master 的数据库
输入 show master status\G
记录下当前使用的 log-bin文件,以及position (比如现在日志是 mysql-bin.000001 ,位置是 107)
然后进入Slave 的数据库
输入 stop slave;
复制代码 代码如下:change master to master_log_file='mysql-bin.000001',master_log_pos=107;
最后输入 start slave;
最后在服务器上执行
复制代码 代码如下:yum -y install ntpdate
ntpdate cn.pool.ntp.org
clock -w
把几台服务器的时间同步
+ ---------------------------- 一些可能用到的命令 ------------------------- +
执行锁表:
复制代码 代码如下:flush tables with read lock;
这一步的目的是使我们在制作主从的过程中,主库中不会有新的数据,否则会给我们的同步设置带来麻烦
主库执行解锁:
复制代码 代码如下: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。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号