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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

菜鸟学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数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
关系型数据库 MySQL Linux
Linux 安装 mysql 【使用 tar.gz | tar.xz安装包-离线安装】
在Linux系统中使用tar.xz压缩包安装MySQL数据库的详细步骤。包括下载MySQL压缩包,解压到指定目录,创建mysql用户和组,设置目录权限,初始化MySQL,配置my.cnf文件,启动服务,以及修改root用户密码。此外,还提供了如何设置Windows远程登录MySQL服务器的方法。
Linux 安装 mysql 【使用 tar.gz | tar.xz安装包-离线安装】
|
8天前
|
关系型数据库 MySQL Linux
Linux 安装 mysql【使用yum源进行安装】
这篇文章介绍了在Linux系统中使用yum源安装MySQL数据库的步骤,包括配置yum源、安装MySQL服务、启动服务以及修改root用户的默认密码。
Linux 安装 mysql【使用yum源进行安装】
|
1月前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
2月前
|
关系型数据库 MySQL Linux
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
|
2月前
|
关系型数据库 MySQL Linux
Linux环境安装MySQL8.0.36使用rpm包安装,安装顺序是什么?
【8月更文挑战第23天】Linux环境安装MySQL8.0.36使用rpm包安装,安装顺序是什么?
165 1
|
2月前
|
SQL 关系型数据库 MySQL
在Linux中,mysql 数据备份工具有哪些?
在Linux中,mysql 数据备份工具有哪些?
|
2月前
|
安全 关系型数据库 MySQL
在Linux中,如何重置 mysql root 密码?
在Linux中,如何重置 mysql root 密码?
|
18天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
20天前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
160 11
|
16天前
|
存储 SQL 关系型数据库
MySQL的安装&数据库的简单操作
本文介绍了数据库的基本概念及MySQL的安装配置。首先解释了数据库、数据库管理系统和SQL的概念,接着详细描述了MySQL的安装步骤及其全局配置文件my.ini的调整方法。文章还介绍了如何启动MySQL服务,包括配置环境变量和使用命令行的方法。最后,详细说明了数据库的各种操作,如创建、选择和删除数据库的SQL语句,并提供了实际操作示例。
58 13
MySQL的安装&数据库的简单操作

热门文章

最新文章

下一篇
无影云桌面