凡事留一手,MySQL配置读写分离

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
日志服务 SLS,月写入数据量 50GB 1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 凡事留一手,MySQL配置读写分离

一.背景



1.什么是读写分离

读写分离从字面上就很好理解,读数据库和写数据库的操作分别执行,读或写操作分别用不同的计算机或计算机组来承担任务。可以参考下基础的架构图。


image.png


2.为什么要读写分离

还不是为了安全,读写分离为主从同步的一种备份方案,当主数据库出现问题的时候,从数据库可以代替主数据库,避免数据丢失,从而更加的安全。

进一步而言,当配置好主从复制后,我们就可以把两台机器做不同的用途,由于从机写入数据时不会同步到主机,因此把主机做写服务器,从机做读服务器,得以分散压力,使得数据库更稳定高效。(一般情况都是读操作更多)


3.下一步?

如果有多个读写服务器组,可以使用多主多从的方式建立,然后使用Nginx代理读和写组服务器,或使用HaProxy或LVS等来组建统一的访问入口,交给开发访问。


二、搭建


主从复制在前一期在复现过,这里来详细阐述my.cnf几个参数。

# 开启二进制日志
log-bin=mysql-bin
# 设置服务器id
server-id=1
# 使用binlog在每N次写入后与硬盘同步
sync-binlog=1
# 5天后自动清理二进制日志
expire_log_days=1

我这里简单搭建:

# 主服务器
docker run \
-p 12345:3306 \
--name mysql_master \
-v /opt/docker/mysql_master/conf:/etc/mysql/conf.d \
-v /opt/docker/mysql_master/logs:/logs \
-v /opt/docker/mysql_master/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7
docker run \
-p 12346:3306 \
--name mysql_node \
-v /opt/docker/mysql_node/conf:/etc/mysql/conf.d \
-v /opt/docker/mysql_node/logs:/logs \
-v /opt/docker/mysql_node/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7

配置文件,分别执行下面两条命令。

cat > /opt/docker/mysql_master/conf/my.cnf << EOF
[mysqld]
# 开启二进制日志
log-bin=mysql-bin
# 设置服务器id
server-id=1
# 使用binlog在每N次写入后与硬盘同步
sync-binlog=1
# 5天后自动清理二进制日志
expire_logs_days=5
EOF
cat > /opt/docker/mysql_node/conf/my.cnf << EOF
[mysqld]
server-id=2
EOF

重启生效

 
         

主节点上操作: 执行以下命令,主节点新建立用户,用于同步。

docker exec -it mysql_master /bin/bash
mysql -uroot -p123456
mysql> CREATE USER 'repl'@'%' identified by '123456';
mysql> GRANT REPLICATION SLAVE ON *.*  TO  'repl'@'%';  
docker restart mysql_master
docker restart mysql_node
# 回到shell 操作界面
quit
exit

从节点上操作:执行以下命令

docker exec -it mysql_node /bin/bash
# 把下面的ip换成你主节点的ip和端口
mysql -uroot -p123456
mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.187', MASTER_PORT=12345,MASTER_USER='repl',MASTER_PASSWORD='123456';
# 启动同步
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
2-2-4:查看同步状态
mysql>  show slave status \G;

如果没有报错,则部署成功。


image.png


验证


在主master上去创建数据库或新建表,加入数据,从节点很快接受到同步,同样的,如果在从node节点上去插入数据的话,主节点的数据无变化。这样就做好了读写分离的实验,后面我们把主master作为读/写节点,nodes作为读节点就好了。


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
6月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
4月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
315 11
|
5月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu 22.04上配置和安装MySQL
以上就是在Ubuntu 22.04上配置和安装MySQL的步骤。这个过程可能看起来有点复杂,但只要按照步骤一步步来,你会发现其实并不难。记住,任何时候都不要急于求成,耐心是解决问题的关键。
611 30
|
5月前
|
关系型数据库 MySQL Linux
CentOS 7系统下详细安装MySQL 5.7的步骤:包括密码配置、字符集配置、远程连接配置
以上就是在CentOS 7系统下安装MySQL 5.7的详细步骤。希望这个指南能帮助你顺利完成安装。
1378 26
|
7月前
|
SQL 关系型数据库 MySQL
如何实现 MySQL 的读写分离?
本文介绍了 MySQL 读写分离的实现方式及其主从复制原理,解释了如何通过主从架构提升读并发能力。重点分析了主从同步延时问题及解决方案,如半同步复制、并行复制等技术手段,并结合实际案例探讨了高并发场景下的优化策略。文章还提醒开发者在编写代码时需谨慎处理插入后立即查询的情况,避免因主从延时导致的数据不一致问题。
926 44
如何实现 MySQL 的读写分离?
|
11月前
|
SQL 关系型数据库 MySQL
mysql主从复制概述和配置
【10月更文挑战第22天】MySQL 主从复制是一种将主服务器的数据复制到一个或多个从服务器的技术,实现读写分离,提高系统性能和可用性。主服务器记录变更日志,从服务器通过 I/O 和 SQL 线程读取并应用这些变更。适用于读写分离、数据备份和恢复、数据分析等场景。配置步骤包括修改配置文件、创建复制用户、配置从服务器连接主服务器并启动复制进程。
357 1
|
5月前
|
存储 Oracle 关系型数据库
MySQL 8.4 配置SSL组复制(八个步骤)
MySQL 8.4 配置SSL组复制(八个步骤)
275 0
|
6月前
|
SQL 关系型数据库 MySQL
seatunnel配置mysql2hive
本文介绍了SeaTunnel的安装与使用教程,涵盖从安装、配置到数据同步的全过程。主要内容包括: 1. **SeaTunnel安装**:详细描述了下载、解压及配置连接器等步骤。 2. **模拟数据到Hive (fake2hive)**:通过编辑测试脚本,将模拟数据写入Hive表。 3. **MySQL到控制台 (mysql2console)**:创建配置文件并执行命令,将MySQL数据输出到控制台。 4. **MySQL到Hive (mysql2hive)**:创建Hive表,配置并启动同步任务,支持单表和多表同步。
|
10月前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
|
10月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
839 2

推荐镜像

更多