mysql 数据库主从同步
1、简介
写这篇文章是网上找到的相关主从同步的都不够完全,本人第一次搭建主从同步,完全看着网上的文章来搭建的,结果你懂的,踩了很多坑。所以特地把踩到的坑写出来,新手切勿直接布置到正式环境,请于测试环境测试完成再布置与正式环境。本文仅供自己或者有需要的参考,仅供参考。
2、环境说明
为了更贴切于实际环境,本人直接采用的真机,壕吧,这里不采用真实IP。下文全部采用IPXXX代替。
一台阿里云ECS(1G1核):IPC193
一台阿里云轻量应用服务器(2G1核): IPC248
系统全装的CentOS 7.4 64位
3、数据库版本
安装包下载地址:http://cdn.mysql.com/archives/mysql-5.6/mysql-5.6.26-linux-glibc2.5-x86_64.tar.gz
4、数据库的安装就不再本文说了,开始搞事情吧。
4.1 安装
安装数据库,我这里是安装在/usr/local/mysql的
4.2 配置
注意:二进制日志必须开启,因为数据的同步实质上就是其他的MySQL数据库服务器将这个数据变更的二进制日志在本机上再执行一遍。
vim /usr/local/mysql/my.cnf
在页面最下方添加 log-bin=mysql-bin 开启二进制日志
C248 为主数据库服务器
C129 为从数据库服务器
4.3 开始搭建主从复制
主数据库C248需要做的操作
在主数据库创建一个从数据库能够登录的账号
#创建具有复制权限的用户
mysql>GRANT REPLICATION SLAVE ON *.* TO '账号名'@'从服务器IP地址' IDENTIFIED BY '密码';
#mysql 新设置用户或更改密码后需用flush privileges刷新MySQL的系统权限相关表,否则会出现拒绝访问
mysql>FLUSH PRIVILEGES;
创建测试账号:c193slave ,测试密码是c193slave@123456
查看主数据库保存的二进制文件名与位置
mysql>SHOW MASTER STATUS;

上图显示的File 对应的binlog.000004 跟Position对应的102219就是从服务器需要用到的,
我这个数据库并不是新数据库,所以Position不是从0开始的,默认File是从000001开始。
从数据库C129需要做的操作
#####CHANGE MASTER TO MASTER_HOST='主数据库IP地址',
MASTER_USER='刚才在主数据库添加的账号',
MASTER_PASSWORD='数据库密码',
MASTER_LOG_FILE='上图对应的File下面的文件名字',
MASTER_LOG_POS=上图图片对应的Position下面数字;
mysql>CHANGE MASTER TO MASTER_HOST='C248',
MASTER_USER='c193slave',
MASTER_PASSWORD='c193slave@123456',
MASTER_LOG_FILE='binlog.000004',
MASTER_LOG_POS=102219;

mysql>START SLAVE; #开启复制
mysql>SHOW SLAVE STATUS\G #查看主从复制是否配置成功

如上图的主数据库IP,账号,等等如果都对应着说明配置成功
5、查看主从复制执行进程
(从服务器)mysql> show processlist; #查看正在执行中的进程,如果出现下图两条则说明从数据库正常

(主服务器)mysql> show processlist; #查看正在执行中的进程,如果出现下图一条则说明主服务器正常

主从复制到此就完成了。
6、在这说一下遇到的坑
白天主从是正常的,但是第二天发现从服务器的position与主服务器并不一致,手动修改了下主服务器数据库,发现从服务器并没有更新,说明主从不正常了。
使用show processlist;查看从数据库线程时,从数据库线程还在,查看主数据库线程时,进程已丢失。反正不知道啥原因丢失了。
经检查,知道了一个叫心跳的东西
在 MySQL 主从复制时,有时候会碰到这样的故障:
在 Slave 上 Slave_IO_Running 和 Slave_SQL_Running 都是 Yes,
Slave_SQL_Running_State 显示 Slave has read all relay log; waiting for the slave I/O thread to update it ,看起来状态都正常,但实际却滞后于主,Master_Log_File 和 Read_Master_Log_Pos 也不是实际主上最新的位置。
一种可能是 Master 上的 binlog dump 线程挂了(我就是线程挂了)。但有时候,在 Master 上检查也是完全正常的。那 Slave 的延误又是怎么造成的呢?
在 MySQL 的复制协议里,由 Slave 发送一个 COM_BINLOG_DUMP 命令后,就完全由 Master 来推送数据,Master、Slave 之间不再需要交互。如果 Master 没有更新,也就不会有数据流,Slave 就不会收到任何数据包。但是如果由于某种原因造成 Master 无法把数据发送到 Slave ,比如发生过网络故障或其他原因导致 Master 上的 TCP 连接丢失,由于 TCP 协议的特性,Slave 没有机会得到通知,所以也没法知道收不到数据是因为 Master 本来就没有更新呢还是由于出了故障。
好在 MySQL 5.5 开始增加了一个复制心跳的功能。
(C129)mysql> stop slave; #关闭主从
(C129)mysql> change master to master_heartbeat_period = 10; #修改心跳为10秒一次
(C129)mysql> set global slave_net_timeout = 25; #修改超时时间
(C129)mysql> start slave; #再次开启主从复制
(C129)mysql> show status like 'slave%';

再次测试主从,数据同步在正常。
mysql 数据库主从同步的更多相关文章
- mysql数据库主从同步
环境: Mater: CentOS7.1 5.5.52-MariaDB 192.168.108.133 Slave: CentOS7.1 5.5.52-MariaDB 192.168. ...
- mysql数据库主从同步读写分离(一)主从同步
1.mysql数据库主从同步读写分离 1.1.主要解决的生产问题 1.2.原理 a.为什么需要读写分离? 一台服务器满足不了访问需要.数据的访问基本都是2-8原则. b.怎么做? 不往从服务器去写了 ...
- MySQL数据库主从同步延迟分析及解决方案
一.MySQL的数据库主从复制原理 MySQL主从复制实际上基于二进制日志,原理可以用一张图来表示: 分为四步走: 1. 主库对所有DDL和DML产生的日志写进binlog: 2. 主库生成一个 lo ...
- Linux下MySQL数据库主从同步配置
说明: 操作系统:CentOS 5.x 64位 MySQL数据库版本:mysql-5.5.35 MySQL主服务器:192.168.21.128 MySQL从服务器:192.168.21.129 准备 ...
- MySQL数据库主从同步实战过程
Linux系统MySQL数据库主从同步实战过程 安装环境说明 系统环境: [root@~]# cat /etc/redhat-release CentOS release 6.5 (Final) ...
- 【转】MySQL数据库主从同步管理
MYSQL主从同步架构是目前使用最多的数据库架构之一,尤其是负载比较大的网站,因此对于主从同步的管理也就显得非常重要,新手往往在出现主从同步错误的时候不知道如何入手,这篇文章就是根据自己的经验来详细叙 ...
- MySQL数据库主从同步安装与配置总结
MySQL的主从同步是一个很成熟的架构,优点为: ①在从服务器可以执行查询工作(即我们常说的读功能),降低主服务器压力: ②在从主服务器进行备份,避免备份期间影响主服务器服务: ③当主服务器出现问题时 ...
- 烂泥:学习mysql数据库主从同步复制原理
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 说明本篇文章部分转载自互联网. MySQL的Replication(英文为复制)是一个多MySQL数据库做主从同步的方案,特点是异步复制,广泛用在各种对 ...
- linux shell mysql 数据库主从同步状态检查告警
需求: 1.监测数据库主从状态 2.获取数据库主要参数 3.可读取配置文件 4.部署位置自适应. 参考资料: http://blog.csdn.net/yf210yf/article/detail ...
随机推荐
- Android 自定义类型文件与程序关联
0x01 功能 实现在其他应用中打开某个后缀名的文件 可以直接跳转到本应用中的某个activity进行处理 0x01 实现 首先创建一个activity ,然后在manifest里对该activity ...
- 键盘坏了几个键位之后,linux上的remap方法
Use xev command to find the keycode xmodmap -pke |more To Change keymapping for this Laptop: 我是日文键盘, ...
- 主成分分析(PCA)原理及R语言实现 | dimension reduction降维
如果你的职业定位是数据分析师/计算生物学家,那么不懂PCA.t-SNE的原理就说不过去了吧.跑通软件没什么了不起的,网上那么多教程,copy一下就会.关键是要懂其数学原理,理解算法的假设,适合解决什么 ...
- 设置RHEL-7.0的运行级别
在RHEL7中修改默认运行级别与7以前版本的修改方式不同(7以前版本可以修改/etc/inittab中的“id:5:initdefault:”参数值来实现),RHEL7在/etc/inittab文件中 ...
- jdbc、jpa、spring data jpa、hibernate、mybatis之间的关系及区别
基础概念 jdbc(Java DataBase Connectivity)是java连接数据库操作的原生接口.JDBC对Java程序员而言是API,对实现与数据库连接的服务提供商而言是接口模型.作为A ...
- 修改 input / textarea placeholder 属性的颜色和字体大小
话不多说,直接上代码: input::-webkit-input-placeholder, textarea::-webkit-input-placeholder { color: #666; fon ...
- Redhat 6.3上安装CMake
在编译libssh时,要用到CMake,而且要依赖3.3以上的版本. 尝试了从CMake官网下载源码,编译安装.结果发现各种依赖,比如要升级GCC,升级Python等等,麻烦要死.搞了半天还是一堆问题 ...
- vue-计算属性和侦听器
1.计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div id="example"> { ...
- 基于Protostuff实现的Netty编解码器
在设计netty的编解码器过程中,有许多组件可以选择,这里由于咱对Protostuff比较熟悉,所以就用这个组件了.由于数据要在网络上传输,所以在发送方需要将类对象转换成二进制,接收方接收到数据后,需 ...
- FtpWebRequest.UsePassive属性:设置FTP工作模式
默认值:true,被动模式 PASV(被动)方式的连接过程是:客户端向服务器的FTP端口(默认是21)发送连接请求,服务器接受连接,建立一条命令链路. 当需要传送数据时, 服务器在命令链路上用PASV ...