总结之:CentOS 6.5 MariaDB或MySQL主从复制详解

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

MySQL Replocation:NySQL复制,MySQL的复制默认为异步工作模式
   mysql的复制功能是mysql内置的,装上它之后就具备了这个功能,而mysql复制是mysql实现大规模高性能应用的一个基本工具,是mysql完成水平扩展的基本架构,为了能够应付更多的访问请求,通常情况下我们需要对服务器进行扩展,而扩展通常有两种方式:向上扩展和向外扩展;
向上扩展:scale on,也称为垂直扩展,一般是扩充服务器的内存或CPU颗数的这种就是向上扩展。
向外扩展:scale out,也称为水平扩展,比较一台服务器不够,再加一台服务器,再不够再加,这种情况就是向外扩展。
其实MySQL的的复制功能就是使用MySQL向外扩展的能力,也就是水平扩展的功能。

   所谓同步的复制:首先主服务器每更新一条数据先写到磁盘文件中,同时还要写一个到二进制日志文件中,从服务器就会到主服务器请求二进制信息保存在中继日志中,保存好后由本地的SQL thread从中继日志应用到从服务器的本地有磁盘文件中,当这个过程完成之后再由从服务器返回确认结果给主服务器,主服务器才返回结果给客户端的。
所谓异步复制:当主服务器要写数据时,先写到本地的磁盘,同时写到二进制文件日志中,写好二进制日志文件后就把结果返回给客户端,至于从服务有没有来主服务器同步二进制日志他不关心。
注意:在做复制时双方的的MySQL要一致,如果不一致,主的要低于从的。
   MySQL主从服务的工作原理图:

wKioL1NJSEbx9Dz0AAOohJbAW-w420.jpg

   这里还要注意,如果从服务器不断的到主服务器来请求数据,发现这些数据已经是最新的数据了,那从服务器的I/O thread将会转为睡眠状态,因为主服务器会通知,而I/O线程不会做轮循,从服务器的二进制日志文件通常是被关闭状态的,从服务器是不允许执行写操作的。

下面来完成主从复制的基本操作步骤:
   1、这里我们要有两台主机、我这里使用克隆主服务器的主机当做从服务器、首先要把虚拟主机关机才可以克隆的:

wKiom1NJSNfwhN9ZAAJ_Vy_-uh0925.jpg

wKioL1NJSM3BkkBdAAEhlLpuEVw165.jpg

wKiom1NJSRGB-e8nAAD6IOmtor0934.jpg


   克隆完之后我们就开机登录、确保主从服务器都正常运行了即可:
wKioL1NJSUrRFE7fAAF5yBfM-pU195.jpg

wKiom1NJSY3jwbtaAAFK_P1knII792.jpg

wKioL1NJSZriZVDuAADbv5yisnU563.jpg

wKioL1NJSbTinPbEAADegnAVVC0676.jpg


   2、做主从复制最重要的一点就是双方的server-id不能相同;然而在主服务器上只需要三步
   1)就是改server-id
   2)启用二进制日志
   3)创建有复制权限的帐号
   # vim /etc/my.cnf

wKioL1NJSenhMWMOAAEgWhtbavw995.jpg


   改好之后保存退出即可,再重启服务器,创建二进制目录:
   # mkdir /data/binlogs
   # chown -R mysql.mysql /data/binlogs
   重启主服务器的mysql服务;
   # service mysqld restart

   而后连接到主服务器上授权一个有复制权限的帐号:
   # mysql -uroot -hlocalhost -p    

1
2
MariaDB [hellodb]> GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO  'repluser' @ '172.16.251.156'  IDENTIFIED BY  'replpass' ;
MariaDB [hellodb]> FLUSH PRIVILEGES;


   3、在从服务器上有以下几步
   1)改server-id
   2)启用中继日志
   3)连接主服务器
   4)启动复制线程
   配置从服务器的相关配置信息:
   # vim /etc/my.cnf

wKioL1NJSkbBRXGvAAE5NomCrFo978.jpg


   # mkdir /data/relaylogs/
   # chown -R mysql.mysql /data/relaylogs
   重启mysql服务:
   # service mysqld restart
   再连到从服务器的mysql服务器上:
   # mysql -uroot -hlocalhost -p
   查看一下从服务器的中继日志是否在启动状态:
   MariaDB [(none)]> SHOW GLOBAL VARIABLES LIKE '%relay%';

wKioL1NJSw2w5rPgAAGcFF1JJ_k231.jpg


   按照上面的步骤再连接主服务器:    

1
2
3
4
5
6
# MASTER_HOST='172.16.251.244' --主服务器的IP地址
# MASTER_USER='repluser' --主服务器上授权复制的用户名
# MASTER_PASSWORD='replpass' --主服务器上授权用名的密码
# MASTER_LOG_FILE='mysql-bin.000006' --主服务器上的日志文件
# MASTER_LOG_POS=245 --主服务器上日志文件的位置
MariaDB [hellodb]> CHANGE MASTER TO MASTER_HOST= '172.16.251.244' ,MASTER_USER= 'repluser' ,MASTER_PASSWORD= 'replpass' ,MASTER_LOG_FILE= 'mysql-bin.000006' ,MASTER_LOG_POS=245;

   但是此时的从服务器还没有工作起来,要使从服务器工作起来还要手动启动复制线程,我们上面的步骤写得很明白:
   MariaDB [(none)]> START SLAVE;
   wKioL1NJTOqRskaJAAHjV-swIII836.jpg
   wKiom1NJTTPRBlyQAAE2gdqxSs4231.jpg

   wKioL1NJTSXS_-QWAAD1fdFHbcA279.jpg

   wKiom1NJTYaABWNsAAD15iPHxl4387.jpg

   OK、到这里主服务器算是配置完成了,仓促整理了一下,有什么不对的地方还望多多提点,在此先谢谢你的关注了!    










本文转自 wei0164 51CTO博客,原文链接:http://blog.51cto.com/tanxw/1394762,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
19天前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
102 10
|
5月前
|
关系型数据库 MySQL Linux
CentOS 7系统下详细安装MySQL 5.7的步骤:包括密码配置、字符集配置、远程连接配置
以上就是在CentOS 7系统下安装MySQL 5.7的详细步骤。希望这个指南能帮助你顺利完成安装。
1366 26
|
11月前
|
SQL 关系型数据库 MySQL
mysql主从复制概述和配置
【10月更文挑战第22天】MySQL 主从复制是一种将主服务器的数据复制到一个或多个从服务器的技术,实现读写分离,提高系统性能和可用性。主服务器记录变更日志,从服务器通过 I/O 和 SQL 线程读取并应用这些变更。适用于读写分离、数据备份和恢复、数据分析等场景。配置步骤包括修改配置文件、创建复制用户、配置从服务器连接主服务器并启动复制进程。
356 1
|
7月前
|
SQL 网络协议 关系型数据库
MySQL 主从复制
主从复制是 MySQL 实现数据冗余和高可用性的关键技术。主库通过 binlog 记录操作,从库异步获取并回放这些日志,确保数据一致性。搭建主从复制需满足:多个数据库实例、主库开启 binlog、不同 server_id、创建复制用户、从库恢复主库数据、配置复制信息并开启复制线程。通过 `change master to` 和 `start slave` 命令启动复制,使用 `show slave status` 检查同步状态。常见问题包括 IO 和 SQL 线程故障,可通过重置和重新配置解决。延时原因涉及主库写入延迟、DUMP 线程性能及从库 SQL 线程串行执行等,需优化配置或启用并行处理
204 40
|
7月前
|
关系型数据库 MySQL 数据库
RDS用多了,你还知道MySQL主从复制底层原理和实现方案吗?
随着数据量增长和业务扩展,单个数据库难以满足需求,需调整为集群模式以实现负载均衡和读写分离。MySQL主从复制是常见的高可用架构,通过binlog日志同步数据,确保主从数据一致性。本文详细介绍MySQL主从复制原理及配置步骤,包括一主二从集群的搭建过程,帮助读者实现稳定可靠的数据库高可用架构。
392 9
RDS用多了,你还知道MySQL主从复制底层原理和实现方案吗?
|
7月前
|
SQL 存储 关系型数据库
MySQL主从复制 —— 作用、原理、数据一致性,异步复制、半同步复制、组复制
MySQL主从复制 作用、原理—主库线程、I/O线程、SQL线程;主从同步要求,主从延迟原因及解决方案;数据一致性,异步复制、半同步复制、组复制
644 11
|
8月前
|
安全 关系型数据库 MySQL
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
774 16
|
9月前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
206 24
|
9月前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
238 14
|
11月前
|
存储 关系型数据库 MySQL
MySQL主从复制原理和使用
本文介绍了MySQL主从复制的基本概念、原理及其实现方法,详细讲解了一主两从的架构设计,以及三种常见的复制模式(全同步、异步、半同步)的特点与适用场景。此外,文章还提供了Spring Boot环境下配置主从复制的具体代码示例,包括数据源配置、上下文切换、路由实现及切面编程等内容,帮助读者理解如何在实际项目中实现数据库的读写分离。
1064 1
MySQL主从复制原理和使用