MySQL 5.5主从复制(Replication)
简介
MySQL的主从复制(Replication),可以保持两台MySQL数据库的内容一致。因为其同步过程是异步的,所以备份数据库上做任何操作,都不会影响主数据库的性能。对游戏后台数据库而言,这是一个重大的优势:对备份数据库的查询、备份等操作都不会影响游戏的线上运行。配置主从复制有许多教程,但都很繁琐。我根据官方文档,总结出一个简单的配置流程。
配置
线上运行的数据库,称之为Master服务器;备份的数据库,称之为Slave服务器。
分别修改两台服务器上的MySQL配置文件/etc/mysql/my.cnf:
Master服务器上加入这两行(直接去掉注释即可):
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
然后重启MySQL:
service mysql restart
Slave服务器加入这一行:
server-id = 2
然后重启MySQL:
service mysql restart
把Master数据库备份传给Slave数据库:
方法一:MyISAM格式可以直接拷贝,速度快:
在Master服务器上备份数据库,可以只有指定的数据库,不同步mysql库:
mkdir /masterdb
mysqlhotcopy --resetmaster --flushlog --addtodest --regexp=<数据库匹配正则表达式> /masterdb
如果原来已经设置过slave,现在要恢复数据,那么
先在Slave服务器上mysql中停止slave模式并重置:
stop slave;
reset slave;
然后关闭mysql:
stop mysql
删除原有同名的数据库。
停止mysql后,把备份的Master数据库目录传到Slave服务器上的mysql目录中,可以用
scp
命令拷贝:scp -r -P <端口> /masterdb/* root@<IP地址>:/Jpcq/MySQL/
拷贝到Slave的文件需要修改owner:
chown -R mysql:mysql *
修改Slave的my.cnf文件,禁止同步mysql库:
replicate-ignore-db=mysql
启动mysql:
start mysql
重新开启slave模式,在mysql中执行:
change master to master_host='<Master IP地址>', master_user='<用户名>', master_password='<密码>';
start slave;
方法二:使用mysqldump,通用,但是慢:
在Master服务器上备份数据库:
mysqldump --all-databases --master-data >apply_slave.sql
把备份文件dbdump.db传到Slave服务器上,恢复数据库:
mysql <apply_slave.sql
在Slave服务器上开启slave模式,在mysql中执行:
change master to master_host='<Master IP地址>', master_user='<用户名>', master_password='<密码>';
start slave;
维护
Slave显示同步状态:
show slave status\G;
显示进程列表:
show processlist\G;
Master显示正在同步的Slaves:
show slave hosts;
Master显示最新binlog位置:
show master status;
MySQL 5.5 - 5.7的改进
- MySQL 5.5的主从复制是单线程的,性能受限。
- MySQL 5.6的不同数据库可以并行,单个数据库还是顺序执行的。
- MySQL 5.7不再受限制,所有Master数据库并行执行的事务,Slave也可以并行执行。
- MySQL 5.7的Slave还支持从多个Master同步数据库。
MySQL 5.5主从复制(Replication)的更多相关文章
- MySQL数据的主从复制、半同步复制和主主复制详解
一.MySQL复制概述 ⑴.MySQL数据的复制的基本介绍 目前MySQL数据库已经占去数据库市场上很大的份额,其一是由于MySQL数据的开源性和高性能,当然还有重要的一条就是免费~不过不知道还能免费 ...
- MySQL数据的主从复制、半同步复制和主主复制详解-转
一.MySQL复制概述 ⑴.MySQL数据的复制的基本介绍 目前MySQL数据库已经占去数据库市场上很大的份额,其一是由于MySQL数据的开源性和高性能,当然还有重要的一条就是免费~不过不知道还能免费 ...
- Mysql的ssl主从复制+半同步主从复制
Mysql的ssl主从复制+半同步主从复制 准备工作 1.主从服务器时间同步 [root@localhost ~]# crontab -e */30 * * * * /usr/sbin/ntpdate ...
- 003.MySQL高可用主从复制新增slave
一 基础环境 主机名 系统版本 MySQL版本 主机IP master CentOS 6.8 MySQL 5.6 172.24.8.10 slave01 CentOS 6.8 MySQL 5.6 17 ...
- MySQL 5.7主从复制从零开始设置及全面详解——实现多线程并行同步,解决主从复制延迟问题!
MySQL 5.7主从复制从零开始设置及全面详解——实现多线程并行同步,解决主从复制延迟问题!2017年06月15日 19:59:44 蓝色-鸢尾 阅读数:2062版权声明:本文为博主原创文章,如需转 ...
- 高可用Mysql架构_Mysql主从复制、Mysql双主热备、Mysql双主双从、Mysql读写分离(Mycat中间件)、Mysql分库分表架构(Mycat中间件)的演变
[Mysql主从复制]解决的问题数据分布:比如一共150台机器,分别往电信.网通.移动各放50台,这样无论在哪个网络访问都很快.其次按照地域,比如国内国外,北方南方,这样地域性访问解决了.负载均衡:M ...
- 为什么mysql要做主从复制?
为什么MySQL要做主从复制(读写分离)? 通俗来讲,如果对数据库的读和写都在同一个数据库服务器中操作,业务系统性能会降低. 为了提升业务系统性能,优化用户体验,可以通过做主从复制(读写分离)来减轻主 ...
- MySQL 5.6 GTID Replication【转】
一. MySQL 5.6引入了GTID的概念,那么GTID是何方神圣?其实也不复杂,就是一个全局事务标示符.使用GTID时,每次事务提交都会在binlog里生成1个唯一的标示符,它由UUID和事务ID ...
- MySQL 5.5 主从复制
MySQL 5.5 主从复制的原理.过程 分为同步复制和异步复制,实际复制架构中大部分为异步复制.复制的基本过程如下: 1).Slave上面的IO进程连接上Master,并请求从指定日志文件的指 ...
- maria(mysql)的主从复制
一.mariadb的基本操作 1.远程连接 mysql -uroot -p -h 127.0.0.1 mysql -uroot -p -h 192.168.226.128 2.赋予远程连接的权限 gr ...
随机推荐
- B-论文一些好的句子
Due to high design and test costs for real many-core chips, simulators which allow exploring the bes ...
- 在 Linux/windows下 命令行中使用和执行 PHP 代码[交互式php]
[注释]在ubuntu下,升级php到7.1版本,虽然提示的是Interactive mode enabled, 但实际上可以直接书写命令,和interactive shell效果一样. 一:wind ...
- 1098 Insertion or Heap Sort
1098 Insertion or Heap Sort (25 分) According to Wikipedia: Insertion sort iterates, consuming one in ...
- (转)memcached的运行状态监控
转自:http://hi.baidu.com/software_one/item/e7e2b5846ba28bcaef083df3 当memcached启动起来并被访问后,如何知道其详细运行情况呢,详 ...
- maven依赖管理
maven依赖管理 1.依赖范围 (依赖相当于java中的import 是否需要导入别的jar包) 使用控制依赖与三种classpath(编译期,测试时期,运行时期)的关系 complie ...
- hdu 1695 GCD 【莫比乌斯函数】
题目大意:给你 a , b , c , d , k 五个值 (题目说明了 你可以认为 a=c=1) x 属于 [1,b] ,y属于[1,d] 让你求有多少对这样的 (x,y)满足gcd(x,y)= ...
- shell工具-cut
cut cut的工作就是“剪”,具体说就是在文件中负责剪切数据用的.cut命令从文件的每一行剪切字节.字符.和字段并将这些字节.字符和字段输出 基本用法 cut [参数] filename # 说明: ...
- iOS笔记之UIKit_UITextField
- (void)viewDidLoad { [super viewDidLoad]; //建立在你已经遵守了<协议UITextFieldDelegate> self.numTF.deleg ...
- CentOS7安装BugFree
1. 安装apache yum install httpd 2. 安装mysql yum install mysql yum install mysql-server 注意: 1)已安装mysql的跳 ...
- CocoaPods的使用(一) 安装
一.什么是CocoaPods? 前言: 思考如何引入一个第三方框架. 例如: 百度地图SDK.友盟.ShareSDK. 信鸽推送等. 从github或某处下载第三方SDK 工程中导入所需要的SDK的文 ...