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。


猜你喜欢
- 参数数量及其作用tf.layers.dense用于添加一个全连接层。函数如下:tf.layers.dense( i
- 在Python我们要判断一个文件对当前用户有没有读、写、执行权限,我们通常可以使用os.access函数来实现,比如:# 判断读权限os.a
- 网上找了挺久,感觉方法都不合适我这新手,想了个歪点子from tkinter import *from tkinter import mes
- 许多共享主机的服务提供商不允许运行你自己的服务进程,也不允许修改 httpd.conf 文件。 尽管如此,仍然有可能通过Web服务器产生的子
- 因为旧电脑不幸挂了,所以要在新电脑上面重新安装Python。一看官网发现已经更新到3.8.5+了,乖乖,真是迭代快啊。虽然之前安装过一次,不
- (5)SELECT (5-2) DISTINCT(5-3)TOP(<top_specification>)(5-1) <s
- 前言 1.实验环境: Python 3.6;2.示例代码地址:下载示例; 3.本文中元素是指列表、元组、字典等集合类数据类型中的下一级项目(
- 前言go mod tidy的作用是把项目所需要的依赖添加到go.mod,并删除go.mod中,没有被项目使用的依赖。Tidy makes s
- 使用PHP开发应用程序,尤其是网站程序,常常需要生成随机密码,如用户注册生成随机密码,用户重置密码也需要生成一个随机的密码。随机密码也就是一
- 本文主要给大家介绍了关于python实现循环购物车功能的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:示例代码# -*- co
- 基本原理讲解:高斯模糊的算法高斯核函数的编写:构建权重矩阵,采用高斯二维分布函数的形式进行处理。需要注意的是,这里我没有特判当sigma =
- 当你提交一个查询的时候,MySQL会分析它,看是否可以做一些优化使处理该查询的速度更快。这一部分将介绍查询优化器是如何工作的。如果你想知道M
- 关于 *args与**args的用法*args 和 **kwargs主要用于函数定义,你可以将不定数量的参数传递给某个函数。*args*ar
- 本文实例讲述了js鼠标按键事件和键盘按键事件用法。分享给大家供大家参考,具体如下:keydown,keyup,keypress:属于你的键盘
- 前言VScode是一个相当优秀的IDE,具备开源、跨平台、模块化、插件丰富、启动时间快、颜值高、可高度定制等等优秀的特质,不愧是微软爸爸的私
- PIL:Python Imaging Library,已经是Python平台事实上的图像处理标准库了。PIL功能非常强大,但API却非常简单
- PHP mysqli_rollback() 函数关闭自动提交,做一些查询,提交查询,然后回滚当前事务:<?php// 假定数据库用户名
- 上一章实现了登录的部分功能,之所以说是部分功能,是因为用户名和密码写成固定值肯定是不可以的,一个整体的功能,至少需要注册,登录,密码修改等,
- 本文实例讲述了js鼠标悬浮出现遮罩层的方法。分享给大家供大家参考。具体实现方法如下:html页面代码:<ul class="
- 需求是根据当前登录用户来显示某个choice字段不同的选择项。先放现在的实现版本。1、重写PushRuleForm的__init__方法,让