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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL DuckDB 分析主实例,集群系列 8核16GB
日志服务 SLS,月写入数据量 50GB 1个月
简介: 凡事留一手,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;
相关文章
|
3月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
413 7
|
3月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
360 11
|
9月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
8月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu 22.04上配置和安装MySQL
以上就是在Ubuntu 22.04上配置和安装MySQL的步骤。这个过程可能看起来有点复杂,但只要按照步骤一步步来,你会发现其实并不难。记住,任何时候都不要急于求成,耐心是解决问题的关键。
810 30
|
7月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
464 11
|
8月前
|
关系型数据库 MySQL Linux
CentOS 7系统下详细安装MySQL 5.7的步骤:包括密码配置、字符集配置、远程连接配置
以上就是在CentOS 7系统下安装MySQL 5.7的详细步骤。希望这个指南能帮助你顺利完成安装。
1856 26
|
10月前
|
SQL 关系型数据库 MySQL
如何实现 MySQL 的读写分离?
本文介绍了 MySQL 读写分离的实现方式及其主从复制原理,解释了如何通过主从架构提升读并发能力。重点分析了主从同步延时问题及解决方案,如半同步复制、并行复制等技术手段,并结合实际案例探讨了高并发场景下的优化策略。文章还提醒开发者在编写代码时需谨慎处理插入后立即查询的情况,避免因主从延时导致的数据不一致问题。
1159 44
如何实现 MySQL 的读写分离?
|
9月前
|
SQL 关系型数据库 MySQL
seatunnel配置mysql2hive
本文介绍了SeaTunnel的安装与使用教程,涵盖从安装、配置到数据同步的全过程。主要内容包括: 1. **SeaTunnel安装**:详细描述了下载、解压及配置连接器等步骤。 2. **模拟数据到Hive (fake2hive)**:通过编辑测试脚本,将模拟数据写入Hive表。 3. **MySQL到控制台 (mysql2console)**:创建配置文件并执行命令,将MySQL数据输出到控制台。 4. **MySQL到Hive (mysql2hive)**:创建Hive表,配置并启动同步任务,支持单表和多表同步。
|
8月前
|
存储 Oracle 关系型数据库
MySQL 8.4 配置SSL组复制(八个步骤)
MySQL 8.4 配置SSL组复制(八个步骤)
502 0
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]

推荐镜像

更多