http://www.cnblogs.com/kevingrace/p/6256603.html---------Mysql主从同步(1)-主从/主主环境部署梳理

原文:http://blog.csdn.net/hsd2012/article/details/51251051

环境简介

主服务器:CentOS6.5下mysql5.6.30 
安装请参考这里网址:http://blog.csdn.net/hsd2012/article/details/51232612 
从服务器:win7下5.6.17

原理简介及优缺点

MySQL从3.23版本开始提供复制功能,复制主要是指将主服务器的DDL和DML操作,通过二进制日志(binLog日志),传到服务的服务器上,然后在从服务器上对这些日志从新执行,从而实现从服务器与主服务器的数据同步。MySQL支持一台主服务器同时向多台从服务器进行复制,从服务器同时也可以作为其他服务器的主服务器,实现链状的复制。

优点

  • 如果主服务器出现问题,可以快速切换到从服务器提供服务。

  • 可以在从服务器上执行查询,降低主服务器的压力

  • 可以在从服务器上执行备份,以避免备份期间影响主服务器的性能

局限

由于MySQL实现的是异步复制,所以主从服务器之间的数据存在一定差异,对实时性要求高的数据仍然需要从主服务器上获得。

前期准备

1.在linux下创建账号 
在win的命令提示符中输入ipconfig,查看ip 
 
因为我的win下ip为192.168.153.1,所以,我创建将Host设置为192.168.153.%,关于原因,可参考这里 
 
2.赋予权限 
 
REPLICATION SLAVE权限针对所有的数据库,只能通过. ,而不能shool.*,因为REPLICATION SLAVE是复制binlog日志。 

3.将主服务器中的数据,复制到从服务器,确保两者搭建主从之前,数据一致。关于这,之前写过一篇文章专门介绍,可以参考这里

配置

主服务器配置

1.开启binlog日志,并设置server_id 

从服务器配置

1.配置server_id 
设置:server-id=2 
 
2.指定主服务器配置格式如下 
change master to 
master_host=’master_host_name’, //从服务器的主机 
master_user=’replication_user_name’,//执行复制用户名 
master_password=’replication_password’,//执行复制用户密码 
master_log_file=’recorded_log_file_name’,//二进制日志文件名 
master_log_pos=’recorded_log_postion’;//复制开始位置

根据我的配置信息 
bin-log信息 
 
复制用户信息 

我执行的配置代码如下: 
change master to 
master_host=’192.168.153.140’, 
master_user=’lidequan’, 
master_password=’lidequan’, 
master_log_file=’bin-log.000003’, 
master_log_pos=120; 

查看从服务器是否已连接主服务器

执行start slave;

执行show processlist;

修改主服务器数据,查看同步效果

在这里修改主服务器数据,主要是执行插入,更新操作。 
操作之前,数据信息如下 

执行插入操作

insert into `class` (`name`) values ('三年二班'),('三年五班'),('三年七班');

  • 1

 
此时从服务器中也有数据了 

执行更新操作

update class set `name`='三年三班' where id=3;

  • 1

观察下图,发现数据确实发生了变化 

删除操作

观察下图,数据也是同步的 

数据表定义操作

1.添加一个student表

CREATE TABLE student(
`id` INT(3) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT'学生编号',
`name` CHAR(10) NOT NULL DEFAULT '' COMMENT'学生名',
`class_id` INT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT'班级编号',
PRIMARY KEY(`id`)
) ENGINE=MYISAM DEFAULT CHARSET=utf8;

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

2.往student表中添加一个字段

ALTER TABLE student ADD COLUMN age TINYINT(2) UNSIGNED NOT NULL DEFAULT 0 COMMENT'学生年龄';

  • 1

指定负责的数据库或者表

可以通过replicate-do-db、replicate-do-table、replicate-ignore-db、replicate-ignore-table或者replicate-wild-do-table来指定主从数据库复制到从数据库的数据库或者表。

关于数据复制的一些重要参数

在上面搭建主从服务器的时候,使用了MASTER_HOST,MASTER_PORT,MASTER_USER,MASTER_PASSWORD,MASTER_LOG_FILE,MASTER_LOG_POS这些参数都要在从服务器上配置,下面再来说几个常用的启动选项,如log_slave_updates、read_only、master_verify_checksum

log_slave_updates

log_slave_updates这个参数用来配置从服务器上的更新操作是否写入二进制日志,默认是不打开的。 
首先我们来看一下刚刚win下mysql的binlog日志内容 
 
可以发现,刚刚我们执行了增、删、改等操作,它并没有记录。 
我们可以看到log_slave_updates是没有启动的 
 
且该属性是只读属性,不可以动态的设置,只能在配置文件中设置,如下图设置将会报错 

read_only

read-only选项:对所有的非临时表进行只读控制。但是有两种特殊情况 
1. 对replication threads例外,以保证slave能够正常的进行replication。 
2. 对于拥有super权限的用户,可以ignore这个选项。 
 
当以没有拥有super权限的用户登录时候,会提示如下: 
 
这样就确保了从数据只负责读数据操作,而拒绝写数据的操作。 
补充: 
SUPER 权限 : 
1. 可以有change master to, kill其他用户的线程的权限。 
2. Purge binary logs 来删除binary log, set global来动态设置变量的权限。 
3. 执行mysqladmin debug命令,开启或者关闭log,在read-only打开时执行update/insert操作。 
4. 执行start slave, stop slave. 
5. 当连接数已经达到max_connections的最大值时,也可以连接到server。

master_verify_checksum

由于软硬件或者网络传输出错,导致主服务器上运行的sql语句与从服务器上运行的sql语句不一致,很难找到问题原因,mysql的开发人员在 5.6 Milestone Development Release版本中加入了 replication event checksum(主从复制事件校验)功能。master_verify_checksum主要用于复制事件校验。当一个event被写入binary log(二进制日志)的时候,checksum也同时写入binary log,然后在event通过网络传输到从服务器(slave)之后,再在从服务器中对其进行验证并写入从服务器的relay log。由于每一步都记录了event和checksum,所以我们可以很快地找出问题所在。

管理与维护

查看从服务器状态

使用show slave stauts; 
 
在查看这些信息中,比较重要的是”slave_io_runing”和”slave_sql_runing”这两个进程 
slave_io_runing :此进程负责从服务器从主服务器上读取Binlog日志,并写入从服务器上的中继日志中。 
Slave_SQL_Runing:此进程负责读取并执行中继日志中的binlog日子。 
只要期中有一个进程的状态时no,则表示复制进程停止。

总结

主从配置 
一、主服务器上配置 
1.创建用户,并赋予REPLICATION SLAVE权限 
2.开启binlog日志,并设置server_id 
二、从服务器配置 
1.指定server_id 
2.指定主服务器配置

备注:

1.win下mysql开启与关闭(前提是需要配置path路径) 

2.server-id做什么用的

    • mysql的同步的数据中是包含server-id的,用于标识该语句最初是从哪个server写入的,所以server-id一定要有的,如果设置多个从服务器,每个从服务器必须有一个唯一的server-id值,必须与主服务器的以及其它从服务器的不相同。

    • 每一个同步中的slave在master上都对应一个master线程,该线程就是通过slave的server-id来标识的;每个slave在master端最多有一个master线程,如果两个slave的server-id 相同,则后一个连接成功时,前一个将被踢掉。

    • 在mysql做主从同步时,要保证一条数据不会陷入死循环,这里就是靠server-id来实现的。

(转)Mysql主从复制搭建及详解的更多相关文章

  1. 大数据学习系列之七 ----- Hadoop+Spark+Zookeeper+HBase+Hive集群搭建 图文详解

    引言 在之前的大数据学习系列中,搭建了Hadoop+Spark+HBase+Hive 环境以及一些测试.其实要说的话,我开始学习大数据的时候,搭建的就是集群,并不是单机模式和伪分布式.至于为什么先写单 ...

  2. MySQL权限授权认证详解

    MySQL权限授权认证详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL权限系统介绍1>.权限系统的作用是授予来自某个主机的某个用户可以查询.插入.修改.删除 ...

  3. mysql数据恢复,binlog详解

    个人博客:mysql数据恢复,binlog详解 binlog日志恢复数据,是挽救错误操作和数据损坏一根救命稻草,所以认识和使用binglog对于技术人员还是很有必要的 binlog一般用于 主从复制 ...

  4. Python中操作mysql的pymysql模块详解

    Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...

  5. PHP mysql与mysqli事务详解

    官方对PHP连接到MySQL数据库服务器的三种主要的API简介如下: http://php.net/manual/zh/mysqli.overview.php PHP mysql与mysqli事务详解 ...

  6. mysql配置文件my.cnf详解

    原文地址:mysql配置文件my.cnf详解 作者:gron basedir = path 使用给定目录作为根目录(安装目录). character-sets-dir = path 给出存放着字符集的 ...

  7. MySQL 执行计划explain详解

    MySQL 执行计划explain详解 2015-08-10 13:56:27 分类: MySQL explain命令是查看查询优化器如何决定执行查询的主要方法.这个功能有局限性,并不总会说出真相,但 ...

  8. mysql学习3:mysql之my.cnf详解

    mysql之my.cnf详解 本文转自:https://www.cnblogs.com/panwenbin-logs/p/8360703.html 以下是 my.cnf 配置文件参数解释: #*** ...

  9. mysql触发器trigger 实例详解

    mysql触发器trigger 实例详解 (转自 https://www.cnblogs.com/phpper/p/7587031.html)   MySQL好像从5.0.2版本就开始支持触发器的功能 ...

随机推荐

  1. ScreenCapture手动卸载教程-Xproer.ScreenCapture

    此教程包含WindowsXP,Windows7(x86) ,Windows7(x64),Firefox,Chrome卸载教程. 1.1. 手动卸载控件-Windows XP 主要步骤如下: 1.关闭所 ...

  2. 跳转AppStore 评分

    -(void)goToAppStore { NSString *str = [NSString stringWithFormat: @"itms-apps://ax.itunes.apple ...

  3. 使用Nmap攻击靶机和使用Wireshark进行嗅探、分析

    使用Nmap攻击靶机和使用Wireshark进行嗅探.分析 在上一次课中已经对Nmap的使用.原理已经做了很多学习,这次的课更多地针对Wireshark进行学习和使用. 使用192.168.200.1 ...

  4. awk基础05-自定义函数和脚本

        在之前文章中,我们都是在命令行中写一些简短的awk命令,而awk做为一门解释型语言,一样是支持脚本运行的. 基本语法 #!/bin/awk -f # 注释 awk 脚本体 #!:同shell, ...

  5. URAL1991 The battle near the swamp 2017-04-12 18:07 92人阅读 评论(0) 收藏

    The battle near the swamp Gungan: Jar Jar, usen da booma!  Jar Jar: What? Mesa no have a booma!  Gun ...

  6. java中null转换成其它类型

    对null进行强转会不会抛错.测试结果是,如果把null强转给对象,是不会抛异常的,因为本身对象是可以为null的.但是如果是基本类型,比如 int i = (Integer)obj的强转,其实内部会 ...

  7. Spring IOC 和 AOP概述

    IoC(控制反转,(Inversion of Control):本来是由应用程序管理的对象之间的依赖关系,现在交给了容器管理,这就叫控制反转,即交给了IoC容器,Spring的IoC容器主要使用DI方 ...

  8. Linux socat轻松实现TCP/UDP端口转发

    1.TCP端口转发 socat -d TCP4-LISTEN:,reuseaddr,fork TCP4: 2.UDP端口转发 socat -T UDP4-LISTEN:,reuseaddr,fork ...

  9. Centos 安装 erlang 环境

    系统 Centos 6.5 64位 Erlang 18.3.4 安装依赖组件 yum install -y gcc gcc-g++ unixODBC unixODBC-devel wxBase wxG ...

  10. cesium随笔 — 简单实现获取三维范围(包括相机高度)

    代码 // 获取当前三维范围 function getCurrentExtent() { // 范围对象 var extent = {}; // 得到当前三维场景 var scene = viewer ...