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

 更新时间:2014年05月12日 13:07:05   作者:  
这篇文章主要介绍了MySQL 5.5主从同步设置笔记分享,需要的朋友可以参考下

先修改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 5.1版本修改密码及远程登录mysql数据库的方法

    mysql 5.1版本修改密码及远程登录mysql数据库的方法

    这篇文章主要介绍了mysql 5.1版本修改密码及远程登录mysql数据库的方法,需要的朋友可以参考下
    2017-04-04
  • mysql exists与not exists实例详解

    mysql exists与not exists实例详解

    这篇文章主要介绍了mysql exists与not exists实例详解的相关资料,鉴于 not exists 的效率往往要高于 not in , 所以一般情况下会使用前者替代后者,需要的朋友可以参考下
    2017-07-07
  • Mybatis mapper动态代理的原理解析

    Mybatis mapper动态代理的原理解析

    这篇文章主要介绍了Mybatis mapper动态代理的原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • MySQL主从复制的原理图解及Java语言示例使用

    MySQL主从复制的原理图解及Java语言示例使用

    这篇文章主要介绍了MySQL的主从复制原理详细分析,读写分离是基于主从复制来实现的。文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • MySQL 密码设置

    MySQL 密码设置

    本文介绍了如何修改一个用户的密码,你可以使用三种方法,GRANT语句、SET PASSWORD语句、直接修改授权表以及使用管理工具mysqladmin。
    2009-04-04
  • 详解JDBC数据库链接及相关方法的封装

    详解JDBC数据库链接及相关方法的封装

    这篇文章主要介绍了详解JDBC数据库链接及相关方法的封装的相关资料,下面是封装的具体类,用到了泛型和反射,希望能帮助到大家,需要的朋友可以参考下
    2017-08-08
  • MySQL 多个%等模糊查询功能实现

    MySQL 多个%等模糊查询功能实现

    这篇文章主要介绍了MySQL 多个%等模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • 详解MySQL是如何解决幻读的

    详解MySQL是如何解决幻读的

    这篇文章主要介绍了MySQL是如何解决幻读的,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • MySQL数据库设计概念及多表查询和事物操作

    MySQL数据库设计概念及多表查询和事物操作

    数据库设计就是根据业务系统具体需求,结合我们所选用的DBMS,为这个业务系统构造出最优的数据存储模型,本文给大家介绍MySQL数据库设计概念及多表查询和事物操作,感兴趣的朋友一起看看吧
    2022-05-05
  • windows环境下mysql的解压安装及备份和还原

    windows环境下mysql的解压安装及备份和还原

    这篇文章主要介绍了windows环境下mysql的解压安装及备份和还原,需要的朋友可以参考下
    2017-09-09

最新评论