MySQL 5.5主从同步设置笔记分享

时间:2024-01-27 10:12:29 

先修改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 'jb51.net';
# 测试环境密码是  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。

标签:MySQL,主从同步
0
投稿

猜你喜欢

  • 拒绝盗图!教你怎么用python给图片加水印

    2022-05-29 21:42:51
  • 如何测试字符串的长度?

    2009-11-11 20:02:00
  • Python实现周期性抓取网页内容的方法

    2023-04-12 01:33:36
  • Python二进制数据结构Struct的具体使用

    2022-07-10 00:01:59
  • 设计的商业价值

    2009-08-13 14:43:00
  • go语言中排序sort的使用方法示例

    2023-09-01 00:07:22
  • 远古幻想ICON 1套+创作思路

    2007-09-30 20:33:00
  • phpinfo 系统查看参数函数代码

    2024-05-13 09:56:51
  • 使用xtrabackup实现mysql备份

    2024-01-21 07:57:57
  • Javascript的匿名函数

    2008-05-07 13:33:00
  • vue父组件中获取子组件中的数据(实例讲解)

    2024-04-10 13:49:24
  • 基于python实现MQTT发布订阅过程原理解析

    2023-05-06 14:45:14
  • JavaScript实现点击按钮切换网页背景色的方法

    2024-04-16 09:02:43
  • 基于OpenCV实现视频循环播放

    2023-07-13 09:10:33
  • Python如何实现定时器功能

    2023-04-13 23:19:28
  • Python使用pyautogui模块实现自动化鼠标和键盘操作示例

    2022-10-27 16:02:25
  • Python装饰器语法糖

    2022-07-10 15:11:34
  • js正则表达式验证密码强度【推荐】

    2024-04-29 13:39:30
  • python中matplotlib实现随鼠标滑动自动标注代码

    2023-09-02 10:49:47
  • Python使用conda如何安装requirement.txt的扩展包

    2022-03-13 23:01:18
  • asp之家 网络编程 m.aspxhome.com