现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库。前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作。

一般在线增加从库有两种方式,一种是通过mysqldump备份主库,恢复到从库,mysqldump是逻辑备份,数据量大时,备份速度会很慢,锁表的时间也会很长。另一种是通过xtrabackup工具备份主库,恢复到从库,xtrabackup是物理备份,备份速度快,不锁表。为什么不锁表?因为自身会监控主库日志,如果有更新的数据,就会先写到一个文件中,然后再回归到备份文件中,从而保持数据一致性。

服务器信息:

主库:192.168.18.212(原有)

从库1:192.168.18.213(原有)

从库2:192.168.18.214(新增)

数据库版本:MySQL5.5

存储引擎:Innodb

测试库名:weibo

一、mysqldump方式

MySQL主从是基于binlog日志,所以在安装好数据库后就要开启binlog。这样好处是,一方面可以用binlog恢复数据库,另一方面可以为主从做准备。

原有主库配置参数如下:

#vimy.cnf

server-id=1#id要唯一

log-bin=mysql-bin#开启binlog日志

auto-increment-increment=1#在Ubuntu系统中MySQL5.5以后已经默认是1

auto-increment-offset=1

slave-skip-errors=all#跳过主从复制出现的错误

1. 主库创建同步账号

mysql>grant all on*.*to'sync'@'192.168.18.%'identified by'sync';

2. 从库配置MySQL

#vimy.cnf

server-id=3#这个设置3

log-bin=mysql-bin#开启binlog日志

auto-increment-increment=1#这两个参数在Ubuntu系统中MySQL5.5以后都已经默认是1

auto-increment-offset=1

slave-skip-errors=all#跳过主从复制出现的错误

3. 备份主库

#mysqldump-uroot-p123--routines--single_transaction--master-data=2--databases weibo>weibo.sql

参数说明:

--routines:导出存储过程和函数

--single_transaction:导出开始时设置事务隔离状态,并使用一致性快照开始事务,然后unlock tables;而lock-tables是锁住一张表不能写操作,直到dump完毕。

--master-data:默认等于1,将dump起始(change master to)binlog点和pos值写到结果中,等于2是将change master to写到结果中并注释。

4. 把备份库拷贝到从库

#scpweibo.sql root@192.168.18.214:/home/root

5. 在主库创建test_tb表,模拟数据库新增数据,weibo.sql是没有的

mysql>create table test_tb(idint,name varchar(30));

6. 从库导入备份库

#mysql-uroot-p123-e'create database weibo;'

#mysql-uroot-p123 weibo

7. 在备份文件weibo.sql查看binlog和pos值

#head-25weibo.sql

--CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=107;#大概22行

8. 从库设置从这个日志点同步,并启动

mysql>change master to master_host='192.168.18.212',

->master_user='sync',

->master_password='sync',

->master_log_file='mysql-bin.000001',

->master_log_pos=107;

mysql>start slave;

mysql>show slave status\G;

ERROR2006(HY000):MySQLserver has gone away

Noconnection.Tryingto reconnect...

Connectionid:90

Currentdatabase:***NONE***

***************************1.row***************************

Slave_IO_State:Waitingformaster to send event

Master_Host:192.168.18.212

Master_User:sync

Master_Port:3306

Connect_Retry:60

Master_Log_File:mysql-bin.000001

Read_Master_Log_Pos:358

Relay_Log_File:mysqld-relay-bin.000003

Relay_Log_Pos:504

Relay_Master_Log_File:mysql-bin.000001

Slave_IO_Running:Yes

Slave_SQL_Running:Yes

......

9. 从库查看weibo库里面的表

可以看到IO和SQL线程均为YES,说明主从配置成功。

mysql>show tables;

+---------------------------+

|Tables_in_weibo|

+---------------------------+

|test_tb|

发现刚才模拟创建的test_tb表已经同步过来!

二、xtrabackup方式(推荐)

在上面配置基础上做实验,先删除掉从库配置:

mysql>stop slave;#停止同步

mysql>resetslave;#清除从连接信息

mysql>show slave status\G;#再查看从状态,可以看到IO和SQL线程都为NO

mysql>drop database weibo;#删除weibo库

此时,从库现在和新装的一样,继续前进!

1. 主库使用xtrabackup备份

#innobackupex--user=root--password=123./

生成一个以时间为命名的备份目录:2015-07-01_16-49-43

#ll2015-07-01_16-49-43/

total18480

drwxr-xr-x5root root4096Jul116:49./

drwx------4root root4096Jul116:49../

-rw-r--r--1root root188Jul116:49backup-my.cnf

-rw-r-----1root root18874368Jul116:49ibdata1

drwxr-xr-x2root root4096Jul116:49mysql/

drwxr-xr-x2root root4096Jul116:49performance_schema/

drwxr-xr-x2root root12288Jul116:49weibo/

-rw-r--r--1root root21Jul116:49xtrabackup_binlog_info

-rw-r-----1root root89Jul116:49xtrabackup_checkpoints

-rw-r--r--1root root563Jul116:49xtrabackup_info

-rw-r-----1root root2560Jul116:49xtrabackup_logfile

2. 把备份目录拷贝到从库上

#scp-r2015-07-01_16-49-43root@192.168.18.214:/home/root

3. 从库上把MySQL服务停掉,删除datadir目录,将备份目录重命名为datadir目录

#sudorm-rf/var/lib/mysql/

#sudomv2015-07-01_16-49-43/ /var/lib/mysql

#sudochownmysql.mysql-R/var/lib/mysql

#sudo/etc/init.d/mysql start

#ps-ef|grepmysql#查看已经正常启动

mysql88321016:55?00:00:00/usr/sbin/mysqld

4. 在主库创建test_tb2表,模拟数据库新增数据

mysql>create table test_tb2(idint,name varchar(30));

5. 从备份目录中xtrabackup_info文件获取到binlog和pos位置

#cat/var/lib/mysql/xtrabackup_info

uuid=201af9db-1fce-11e5-96b0-525400e4239d

name=

tool_name=innobackupex

tool_command=--user=root--password=..../

tool_version=1.5.1-xtrabackup

ibbackup_version=xtrabackup version2.2.11based onMySQLserver5.6.24Linux(x86_64)(revisionid:)

server_version=5.5.43-0ubuntu0.12.04.1-log

start_time=2015-07-0116:49:43

end_time=2015-07-0116:49:46

lock_time=1

binlog_pos=filename'mysql-bin.000001',position429#这个位置

innodb_from_lsn=0

innodb_to_lsn=1598188

partial=N

incremental=N

format=file

compact=N

compressed=N

6. 从库设置从这个日志点同步,并启动

mysql>change master to master_host='192.168.18.212',

->master_user='sync',

->master_password='sync',

->master_log_file='mysql-bin.000001',

->master_log_pos=429;

mysql>start slave;

mysql>show slave status\G;

***************************1.row***************************

Slave_IO_State:Waitingformaster to send event

Master_Host:192.168.18.212

Master_User:sync

Master_Port:3306

Connect_Retry:60

Master_Log_File:mysql-bin.000001

Read_Master_Log_Pos:539

Relay_Log_File:mysqld-relay-bin.000002

Relay_Log_Pos:363

Relay_Master_Log_File:mysql-bin.000001

Slave_IO_Running:Yes

Slave_SQL_Running:Yes

......

7. 从库查看weibo库里面的表

可以看到IO和SQL线程均为YES,说明主从配置成功。

mysql>show tables;

+---------------------------+

|Tables_in_weibo|

+---------------------------+

|test_tb|

|test_tb2|

发现刚才模拟创建的test_tb2表已经同步过来。

原文发布时间为:2015-07-10

本文来自云栖社区合作伙伴“Linux中国”

mysql 停从库_不停止 MySQL 服务增加从库的两种方式相关推荐

  1. MySQL增加外键的两种方式

    MySQL增加外键的两种方式 *根据需求建一下表 i: emp表 ii:dept表 *1.增加外键(创建表的时候) 代码实现(工具:Navicat 12 for MySQL) CREATE TABLE ...

  2. mysql增加从库_不停止MySQL服务增加从库的两种方式 (装载)

    现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库.前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作. ...

  3. java 深拷贝 流_(转)Java技巧:深拷贝的两种方式

    ⑴浅复制(浅克隆) 被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象.换言之,浅复制仅仅复制所考虑的对象,而不复制它所引用的对象. ⑵深复制(深克隆) 被复制 ...

  4. java 不重启部署_编译Java类后不重启Tomcat有两种方式:热部署、热加载

    不重启Tomcat有两种方式:热部署.热加载 热部署:容器状况在运行时重新部署整个项目.这类环境下一般整个内存会清空,重新加载,这类方式 有可能会造成sessin丢失等环境.tomcat 6确实可以热 ...

  5. python repair修复功能_详解Python修复遥感影像条带的两种方式

    GDAL修复Landsat ETM+影像条带 Landsat7 ETM+卫星影像由于卫星传感器故障,导致此后获取的影像出现了条带.如下图所示, 影像中均匀的布满条带. 使用GDAL修复影像条带的代码如 ...

  6. 怎么把好几行弄成一行_将多行内容合并成一行的两种方式

    在利用Unix操作系统在实现一些具体应用的时候,可能需要把某些显示的结果进行行与行之间的合并.如现在需要用Unix操作系统设计一个彩票软件,每一张彩票上最多可以打印五注内容.在Unix操作系统的数据文 ...

  7. STM32低功耗停止模式 以及简述判断中断的两种方式

    #include "wkup.h" #include "led.h" #include "delay.h" // //本程序只供学习使用,未 ...

  8. mysql不停止重启服务器_不停止MySQL服务增加从库的两种方式

    现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库.前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作. ...

  9. mysql主库从库在同一台服务器_通过两种方式增加从库——不停止mysql服务

    一般在线增加从库有两种方式,一种是通过mysqldump备份主库,恢复到从库,mysqldump是逻辑备份,数据量大时,备份速度会很慢,锁表的时间也会很长.另一种是通过xtrabackup工具备份主库 ...

最新文章

  1. AutoX江苏超级工厂首曝光!机械臂随处可见,车辆出厂就能完全无人驾驶
  2. UITextField与UITextView的区别
  3. springboot异步注解_SpringBoot如何实现异步、定时任务?
  4. 【剑指offer】面试题10- I:斐波那契数列(Java)
  5. 巧用 | 低成本高可用,巧用Redis
  6. SciPy 非线性方程求解 | Python技能树征题
  7. 【译文 Part 1】NEO vs. ETH--为什么NEO可能是2018最强数字货币?
  8. 华为击败思科 赢得阿曼2600万美元NGN合同
  9. 《疯狂的程序员》经典语录
  10. QQ小程序开发之 一些前期准备:预约开发账号、下载安装开发者工具、创建qq小程序
  11. 五分钟轻松搞定产品需求文档!这可能史上最全PRD文档模板
  12. 全面理解 DNS 及 HTTPDNS
  13. 详解区块链P2P网络
  14. [OpenCV] cv.remap() 重映射学习笔记/map1 map2易混点
  15. navicat使用和测试
  16. python数据抓取工具_【重磅开源】Hawk-数据抓取工具:简明教程
  17. Spark First Sample Demo
  18. Win11,MySQL8 安装教程。
  19. Java 网络编程之swing图形化QQ聊天室
  20. vmware虚拟机挂载ISO镜像并创建本地yum源

热门文章

  1. 排球计分程序重构(五上篇)
  2. 寫程式不需要天份,也不需要熱情
  3. 第二阶段第五次站立会议
  4. 开发一款浏览器内核需要学习哪些方面的知识?
  5. Codeforces 405D 数学问题
  6. Script:列出没有主键或唯一索引的表
  7. 《当程序员的那些狗日日子》(五十四)转折
  8. java基础之----java常见异常及代码示例
  9. 【实践】CTR预估在动态样式建模和特征表达学习方面的进展
  10. 全球首发!计算机视觉Polygon Mesh Processing读书笔记——5微分几何中的弧长