开发者社区> 科技探索者> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

菜鸟学Linux 第095篇笔记 MySQL 5.6主从复制

简介:
+关注继续查看

菜鸟学Linux 第095篇笔记 MySQL 5.6主从复制




内容总览

主从服务器复制过滤

MySQL 5.6

简单主从模式配置步骤

mysql-proxy








主从服务器复制过滤

主服务器配置

基于数据库过虑

binlog-do-db =

binlog-ignore-db =


从服务器配置

基于数据库过虑

replicate-do-db =

replicate-ignore-db =

基于表过虑

replicate-do-table =

replicate-ignore-table =

基于表过虑(可以使用通配符)如匹配以表mysk开头的表mydb.mysk%

replicate-wild-do-table =

replicate-wild-itnore-table =

(注意主从只需要设置一边即可使主从服务器只复制某db,table但是推荐从服务器配置此设置

因为主服务器配置的是不再往二进制日志文件中写有关某个数据库或表的二进制操作,即从服务器

便可无法接收到某些数据库或表的操作,但当主服务器还原数据库时,某些表因为设置了不写入二

进制日志文件记录即无法还原,所以如果要配置只复制某些表的话,建议使用从服务器端配置)



MySQL 5.6

GTID 由服务器的UUID和事务编号构成,来标识某一个服务器的某个事务标识码

 二进制日志某一个操作的记录会有此标识GTID

 使追踪事务和比较事务变得简单,也使mysql服务器从崩溃中恢复变得简单

 尤其当启用ha的mysql


Multi-Threaded Slaves 多线程复制(加快数据复制)

每个数据库一个线程(只当主服务器有多个数据库时才会加快复制速度,如果只有一个你懂得)

mysql> SHOW SLAVE STATUS\G;

sql_thread 是用来从中继日志中读取操作再次在本地服务器重新执行一次

slave-parallel-workrs 则是配置sql_thread线程的个数

slave-parallel-sowrks = 0 表示不启用多线程复制的功能


复制管理工具 https://launchpad.net/mysql-utilities 依赖于pathon 2.7

1. replicate相关的命令 2. check相关的命令 3. show相关的命令 4. ha相关的命令

mysql官方提供

mysqlreplication

实现快速启动mysql从服务器复制

mysqlrplcheck

提供简单的验证和快速故障解决,检查binlog是否启用,显示和配置异常情况

mysqlrplshow

发现并显示复制拓扑图,显示主服务器和从服务器以及主机名和端口号

mysqlrplfailover

可以自动或手动的提供一个slave为master

mysqlrplpladmin

可以管理一个主服务的上线和下线,在下线的同时还会使其它的从提升为主,

进而来维护刚刚下线的服务器



一、简单主从模式配置步骤

准备工作安装mysql5.6 


1、配置主从节点的服务配置文件


1.1、配置master节点:

[mysqld]

binlog-format=ROW

log-bin=master-bin

log-slave-updates=true

gtid-mode=on 

enforce-gtid-consistency=true

master-info-repository=TABLE

relay-log-info-repository=TABLE

sync-master-info=1

slave-parallel-workers=2

binlog-checksum=CRC32

master-verify-checksum=1

slave-sql-verify-checksum=1

binlog-rows-query-log_events=1

server-id=1

report-port=3306

port=3306

datadir=/mydata/data

socket=/tmp/mysql.sock

report-host=192.168.11.131


1.2、配置slave节点:

[mysqld]

binlog-format=ROW

log-slave-updates=true

gtid-mode=on 

enforce-gtid-consistency=true

master-info-repository=TABLE

relay-log-info-repository=TABLE

sync-master-info=1

slave-parallel-workers=2

binlog-checksum=CRC32

master-verify-checksum=1

slave-sql-verify-checksum=1

binlog-rows-query-log_events=1

server-id=11

report-port=3306

port=3306

log-bin=mysql-bin.log

datadir=/mydata/data

socket=/tmp/mysql.sock

report-host=192.168.11.132



2、创建复制用户

主服务器配置

mysql> GRANT REPLICATION SLAVE ON *.* TO repluser@192.168.11.132 IDENTIFIED 

BY 'replpass';  一条命令


说明:192.168.11.132是从节点服务器;如果想一次性授权更多的节点,可以自行根据

需要修改   (至此配置完成)



mysql-proxy

是一个mysql代理软件,使用lua脚本可以实现将后台的主从服务器读写分离,即将读操作分配给

从服务器,而写操作分配给主服务器,当有多台从服务器时,要想均衡使用从服务器则需要架构

一台LB服务器,使其实现负载均衡。

本文转自Winthcloud博客51CTO博客,原文链接http://blog.51cto.com/winthcloud/1895010如需转载请自行联系原作者


Winthcloud

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
《MySQL入门很轻松》第1章:初识数据库与MySQL----MySQL安装
MySqQL支持多种平台,不同平台的安装与配置过程也不相同。本文以Windows安装图形化MySQL为例
57 0
在ECS实例上安装MySQL
在ECS实例上安装MySQL,步骤如下
104 0
手把手教你在Windows 11安装MySQL 8.0
1. 官网下载安装包 下载地址: dev.mysql.com/downloads/m… 通过下载页面可以选择安装包或者是压缩包。 这里选择安装文件(Installer MSI)
314 0
如何在 Linux 安装 MySQL 数据库
本教程手把手教你如何在 Linux 安装 MySQL 数据库,以 CentOS 8为例。 之前,我买了阿里云的服务器centos7,安装mysql,特此记录一下,方便自己以后查找使用 1. 下载并安装 MySQL 官方的 Yum Repository
285 0
Linux (centos8)安装 MySQL 8 数据库(图文详细教程)
本教程手把手教你如何在 Linux 安装 MySQL 数据库,以 CentOS 7为例。
84 0
Linux (centos8)安装 MySQL 8 数据库(图文详细教程)
今天2021年4月23日。我买了阿里云centos服务器,安装mysql8.0,做一笔记,以供大家使用。 本教程手把手教你如何在 Linux 安装 MySQL 数据库,以 CentOS 8为例。
398 0
从零到一上手玩转云服务器-- mysql安装体验
第一期,主要是熟悉一下ecs的创建与管理 ,mysql的安装及服务启动,yum源的配置,快速搭建门户网站。
35 0
冬季实战营第一期 之 安装并配置MySQL
MySQL是最流行的RDBMS(Relational Database Management System:关系数据库管理系统)之一,原开发者为瑞典的MySQL AB公司,该公司于2008年被昇阳微系统(Sun Microsystems)收购。2009年,甲骨文公司(Oracle)收购昇阳微系统公司,MySQL成为Oracle旗下产品。
53 0
MySQL 在 windows 下的安装|学习笔记
快速学习MySQL 在 windows 下的安装
47 0
文章
问答
文章排行榜
最热
最新
相关电子书
更多
深入MySQL实战
立即下载
MySQL高并发场景实战
立即下载
Oracle 和 MySQL 性能优化感悟
立即下载