mysql的主从复制原理
一个简单完整的 Mysql 主从复制,读写分离的示意图。

1. 首先搭建 Mysql 主从架构,实现 将 mater 数据自动复制到 slave
MySQL 复制的工作方式很简单,一台服务器作为主机,一台或多台服务器作为从机。主机会把数据库的变化记录到日志。一旦这些变化被记录到日志,就会立刻(或者以设定的时间间隔)被送到从机。

使用MySQL 复制提供扩展大型网站的能力,这些大型网站的数据库主要是读操作(SELECTs)。从机用於复制主机的銷秏是很少的(通常每个从机1%的开销),在大型网站中每个主机部署30 个从机也是常见的。
异步复制与同步复制
异步复制:MySQL本身支持单向的、异步的复制。异步复制意味着在把数据从一台机器拷贝到另一台机器时有一个延时 –
最重要的是这意味着当应用系统的事务提交已经确认时数据并不能在同一时刻拷贝/应用到从机。通常这个延时是由网络带宽、资源可用性和系统负载决定的。然
而,使用正确的组件并且调优,复制能做到接近瞬时完成。
同步复制:同步复制可以定义为数据在同一时刻被提交到一台或多台机器,通常这是通过众所周知的“两阶段提交”做到的。虽然这确实给你在多系统中保持一致性,但也由于增加了额外的消息交换而造成性能下降。
使用MyISAM或者InnoDB存储引擎的MySQL本身并不支持同步复制,然而有些技术,例如分布式复制块设备(简称DRBD),可以在下层的
文件系统提供同步复制,允许第二个MySQL服务器在主服务器丢失的情况下接管(使用第二服务器的复本)。要了解更多信息,请参
见:http://www.drbd.org/

异步复制方案:
1. Mysql 数据库安装
安装过程省略: 详细参见:http://pengranxiang.iteye.com/admin/blogs/1138059
服务器 Master :192.168.14.131
Mysql 安装目录: /home/mysql/mysql (使用源码安装,独立目录)
服务器 Slave :192.168.14.132
Mysql 安装目录 :/home/mysql/mysql
2. 修改配置
为了不影响原来的配置文件: /etc/my.cnf
创建新的配置文件,
cp /etc/my.cnf /home/mysql/mysql/conf/master.cnf
cp /etc/my.cnf /home/mysql/mysql/conf/slave.cnf
修改 master.cnf, 增加下面的设置 ,
(官方说明:为了使用事务的InnoDB在复制中最大的持久性和一致性,你应该指定innodb_flush_log_at_trx_commit=1,sync_binlog=1选项。)
- log-bin=mysql-bin #slave会基于此log-bin来做replication
- server-id=1 #master的标示
- innodb_flush_log_at_trx_commit=1
- sync_binlog=1
修改 slave.cnf
- [mysqld]
- server-id=2 #slave的标示
3. 启动服务
- # Master
- # 如果 Mysql 已启动,先关掉。
- /home/mysql/mysql/bin/mysqladmin -u root -p shutdown
- # 使用修改过的 master.cnf 启动 mysql
- /home/mysql/mysql/bin/mysqld_safe --defaults-file=/home/mysql/mysql/conf/master.cnf &
- # Slave
- # 如果 Mysql 已启动,先关掉。
- /home/mysql/mysql/bin/mysqladmin -u root -p shutdown
- # 使用修改过的 slave.cnf 启动 mysql
- /home/mysql/mysql/bin/mysqld_safe --defaults-file=/home/mysql/mysql/conf/slave.cnf &
4. 在 Master 上创建一个专门用于复制的账号 repl_user

5. 启动主从复制功能
需要查看 Master 中的 Master status
mysql> show master status;
然后再 Slave 中,启动复制

上面窗口是连接 Master , 下面窗口连接 Slave
6. 测试复制
在 Master 中插入一条数据, 然后在 Slave 中查询。 可以验证。

2 简单的读写分离实现
读写分离可以直接在 客户端 实现, 也可以通过 代理服务器 实现。
代理服务器一般可以选择:
官方的:mysql proxy 地址:http://dev.mysql.com/downloads/mysql-proxy/#downloads
国产开源项目:amoeba
Amoeba开源项目地址: http://www.sourceforge.net/projects/amoeba
amoeba 中文文档下载地址:http://amoeba.meidusa.com/amoeba.pdf
这里只演示最简单的方案: JDBC 直接实现 读写分离。
- package prx.dao;
- import java.sql.Connection;
- import java.sql.ResultSet;
- import java.util.Properties;
- import com.mysql.jdbc.ReplicationDriver;
- public class Test {
- public static void main(String[] args) throws Exception {
- ReplicationDriver driver = new ReplicationDriver();
- Properties props = new Properties();
- // We want this for failover on the slaves
- props.put("autoReconnect", "true");
- // We want to load balance between the slaves
- props.put("roundRobinLoadBalance", "true");
- props.put("user", "foo");
- props.put("password", "bar");
- //
- // Looks like a normal MySQL JDBC url, with a
- // comma-separated list of hosts, the first
- // being the 'master', the rest being any number
- // of slaves that the driver will load balance against
- //
- Connection conn = driver.connect(
- "jdbc:mysql://master,slave1,slave2,slave3/test", props);
- //
- // Perform read/write work on the master
- // by setting the read-only flag to "false"
- //
- // 通过 conn 的 readOnly 是否为 true 来判断,要取 connection 连接的数据库是 主数据库,还是从数据库
- // false 为 主数据库的连接
- // true 为 从数据库的连接
- conn.setReadOnly(false);
- conn.setAutoCommit(false);
- conn.createStatement().executeUpdate("UPDATE some_table ....");
- conn.commit();
- //
- // Now, do a query from a slave, the driver automatically picks one
- // from the list
- //
- conn.setReadOnly(true);
- ResultSet rs = conn.createStatement().executeQuery(
- "SELECT a,b FROM alt_table");
- }
- }
mysql的主从复制原理的更多相关文章
- mysql的主从复制原理与实现
关于mysql的主从复制,之前一直在听说这个话题,一直没有实现,昨天学习了下,原来是这么回事: 既然是主从复制,那么肯定有主有从,也就说一个主数据库(一般为写库),一个从数据库(读库).主数据库更新了 ...
- Mysql数据库主从复制搭建
Mysql数据库主从复制原理: 主库开启bin-log日志,同时生成IO线程.IO线程负责将用户写入数据库的sql语句记录在二进制日志bin-log,该记录过程可并发进行:生成标识号 server i ...
- mysql 主从复制原理
主从形式 mysql主从复制 灵活 一主一从 主主复制 一主多从---扩展系统读取的性能,因为读是在从库读取的: 多主一从---5.7开始支持 联级复制--- 用途及条件 mysql主 ...
- [转]MySQL主从复制原理介绍
MySQL主从复制原理介绍 一.复制的原理 MySQL 复制基于主服务器在二进制日志中跟踪所有对数据库的更改(更新.删除等等).每个从服务器从主服务器接收主服务器已经记录到其二进制日志的保存的更新,以 ...
- Mysql中主从复制的原理、配置过程以及实际案例
Mysql中主从复制的原理.配置过程以及实际案例1.什么是主从复制?原理:主从分离,什么意思呢?我们不妨画个图看看.如图1所示: 2.准备工作:预备两台服务器,我这里使用虚拟机安装了两个Centos6 ...
- Mysql主从复制原理及配置
Mysql主从复制原理及配置 1.复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其 ...
- MySQL主从复制--原理
简介 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重新执行一 ...
- MySQL(4):主从复制原理
1.主从复制概述 MySQL主从复制也可以称为MySQL主从同步,它是构建数据库高可用集群架构的基础.它通过将一台主机的数据复制到其他一台或多台主机上,并重新应用relay log中的SQL语句来实现 ...
- mysql 主从复制原理(转)
本文转自https://blog.csdn.net/php_younger/article/details/59673879 mysql 主从复制原理 主从形式 mysql主从复制 灵活 一主一从 ...
随机推荐
- 《Java程序员面试笔试宝典》之switch使用时有哪些注意事项
switch语句用于多分支选择,在使用switch(expr)的时候,expr只能是一个枚举常量(内部也是由整型或字符类型实现)或一个整数表达式,其中整数表达式可以是基本类型int或其对应的包装类In ...
- pyqt 自定义例子学习
# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' import sys from PyQt4.QtCore impor ...
- [重磅] 让HTML5达到原生的体验 系列之中的一个 避免切页白屏
非常多人都想.甚至曾使用HTML5开发跨平台App.而且想达到原生App的体验. 最后的结果都是无奈的放弃.HTML5貌似美好,但坑太多.想做到原生App的体验差点儿不可为. 也曾有过著名的faceb ...
- ZooKeeper的学习与应用
近期大概学习了一下ZooKeeper,本身并没有深入.LGG尝试着在虚拟机里面搭了平台,看了看一些教材,从网上到处看别人的博文并引用之,还请各位大牛们谅解我的剽窃.现总结例如以下. 1. ZooKee ...
- Xcode 常用快捷键及代码自动排版
1. 文件CMD + N: 新文件CMD + SHIFT + N: 新项目CMD + O: 打开CMD + S: 保存CMD+OPt+S:保存所有文件CMD + SHIFT + S: 另存为CMD + ...
- ios变量的property属性设置和意义
IOS 的@property和@synthesize帮我们轻易的生成对象的getter和setter方法来完成对对象的赋值和访问.但是如果我们如果要动态设置对象的getter和setter方法可以使用 ...
- uva 1595 Symmetry“结构体”
给出平面上N(N<=1000)个点.问是否可以找到一条竖线,使得所有点左右对称,如图所示: 则左边的图形有对称轴,右边没有. Sample Input 3 5 -2 5 0 0 6 5 4 ...
- 1、Servlet 2、ServletConfig 3、ServletContext 4、HttpUrlConnection
1.Servlet 2.ServletConfig 3.ServletContext 4.HttpUrlConnection 07. 五 / J2EE / 没有评论 一.第一个Servlet的编写 ...
- NopCommerce 3.3中文语言包发布下载及使用
NopCommerce 3.3是一套国外优秀的开源电子商务项目,其拥有完整的电子商务功能且具有灵活的配置功能,基于微软最新技术ASP.NET MVC 5.1.1,EntityFramework.6.1 ...
- struts2 0day漏洞
描述 Apache Struts2 近日出现一个0day漏洞,该漏洞在修补CVE-2014-0050和2014-0094两个安全漏洞处理不当,分别可以导致服务器受到拒绝服务攻击和被执行恶意代码. 漏洞 ...