master数据库已投入生产一段时间后,做主从复制的操作记录

环境:

master库:172.18.237.13
slave库:172.18.237.14

mysql版本说明:

master:mysql 5.6.33

slave:mysql 5.6.35

已经装了5.6.33版本,找了很久没有找到5.6.33版本的包,勉强找到了5.6.35版本的包,只能硬头皮用着(最终主从搭建成功,暂时未发现其他异常)

1、确保master、slave服务器时间同步

yum -y install ntp

ntpdate  time.pool.aliyun.com #最好使用crontab做为任务定时时间同步

systemctl start ntpd

systemctl enable ntpd

2、修改master库my.cnf文件开启主从配置以及bin-log,加入如下配置参数:

#开启主从和binlog日志记录
server-id = 52
log-bin = mysql-bin
#binlog日志定期清理,单位天。
expire_logs_days = 5
#binlog日志保存路径和文件名,可根据实际目录进行改写
log-bin = /usr/local/mysql/data/binlogs/mysql-bin
#使用混合模式复制
binlog_format = mixed
#binlog每个日志文件大小
max_binlog_size = 100M
#binlog缓存大小
binlog_cache_size = 4M
#最大binlog缓存大小
max_binlog_cache_size = 512M
3、重启master数据库,使其主从配置生效。
service mysqld restart

/usr/local/mysql/data/binlogs/下已经存在bin-log日志表示成功开启bin-log日志记录

4、master数据库授权slave服务器主从同步帐号
grant replication slave on *.* to tb@'172.18.237.14' identified by '123456';

5、锁定主数据库,只允许读不许写入。

FLUSH TABLES WITH READ LOCK;
6、再进入master数据库,查看master状态,查看bin-log文件名以及position点,并做记录,slave连接master时会用到
show master status;
如:
File        | Position
mysql-bin.000001 | 120

###这里通过mysqlbinlog工具将不可直接读取的bin-log日志转换为可读格式在进行查看。

###mysqlbinlog mysql-bin.000001 >abc.txt

##head -n10 abc.txt

7、备份master数据库至all.sql,可排除数据库系统库(Database|performance_schema|information_schema|mysql|test)|也可以不排除
mysql -e "show databases;" -uroot -p| grep -Ev "Database|performance_schema|information_schema|mysql|test" | xargs mysqldump -uroot -p --databases > all.sql
8、将all.sql备份文件scp至slave服务器

scp all.sql root@172.18.237.14:/root/

9、进入slave服务器将mysql的data目录中的文件进行备份(内容仅仅是初装的系统库等文件)

cp  /data/mysql56  /data/mysql56.bak

10、再用all.sql还原到slave数据库中
mysql -uroot -p <all.sql

11、提前将bin-log日志存放目录创建并将其所属用户、用户组改为mysql,后续my.cnf配置将加入日志存放路径

cd /usr/local/mysql/data/

mkdir binglogs

chown -R mysql:mysql binglogs

13、进入slave服务器,修改slave库my.cnf配置文件,开启主从模式

#不能与master的值一致
server-id = 203
#从数据库通常要求只读(可以限定普通用户进行数据修改的操作,但不会限定具有super权限的用户(如超级管理员root用户)的数据修改操作。)
read_only=1
#还可以添加其他参数...

14、重启slave,使其主从配置生效
service mysqld restart
15、连接master数据库,配置master的相关参数并启动slave(position点用上面第6步查到的点)
change master to master_host='172.18.237.13',master_user='tb',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=120;
start slave;
16、查看主从连接状态
show slave status\G;
如下所示表示主从创建成功:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

17、到master数据库解锁表

UNLOCK TABLES;

18、观察slave状态中的Read_Master_Log_Pos点是否在不断的变化,若变化表示已经有新数据库同步

show slave status\G;

最新文章

  1. 讲解Python中的递归函数
  2. js作用域和词法分析
  3. POJ2125 Destroying The Graph (最小点权覆盖集)(网络流最小割)
  4. Eclipse 快捷键 快捷输入
  5. Day7 - Python基础7 面向对象编程进阶
  6. 基于live555的一个简单RTSP服务器
  7. sed简单实例练习
  8. mysql关于char和varchar的查询效率问题
  9. Python3 OS 文件/目录方法
  10. os模块(操作系统)
  11. LINQ的增删改查写法&amp;&amp;组合查询
  12. Python学习笔记 --第二章
  13. UIStatusBarStyle PreferredStatusBarStyle does not work on iOS 7
  14. EA修改生成代码的表头注释
  15. CSS表格(未完成)
  16. linux命令:linux权限管理命令
  17. HDU 1757 A Simple Math Problem(矩阵快速幂模板)
  18. Scrum 团队成立 -- 软件工程
  19. 如何创建XHTML表单
  20. 使用自定义模板来弥补eclipse没有新建Filter的功能

热门文章

  1. sql compare options
  2. YTU 2500: 二元表达式计算
  3. 雅礼集训 2017 Day1
  4. openStack集群封装记录
  5. 3-4章 第3章 form表单组件与小程序前后端通信
  6. HTML5常用知识点
  7. Odoo免费开源企业信息化平台助力企业成功
  8. ROS-URDF仿真
  9. [BZOJ3224/Tyvj1728]普通平衡树
  10. msxml3.dll 错误 &#39;800c0005&#39; 系统错误: -2146697211。