JAVA程序实现mysql读写分离并在kubernetes中演示

1 概述

对数据进行读写分离,可以将读流量从主数据库中剥离出来,进一步降低读操作对写操作的影响。读写分离的实现可以有多种方式,例如通过proxySQL、mycat等中间件来实现,也可以在应用进程内实现。本文介绍JAVA程序通过spring框架和mybatis框架对mysql主从集群进行读写分离。

2 程序思路

1)配置文件写入两个或以上的数据源。

2)javax.sql.DataSource是一个接口,实现类org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource具备一个按照一个字符串key选择一个具体数据源的能力。mybatis框架会自动使用该实现类,只需要在该类增加@Primary。

考虑到取出key是并发的,需要使用到ThreadLocal类。

3)对mapper的方法新增一个切面

4)mapper保持不变即可

3 完整程序git地址

复制代码
https://gitee.com/handsomeboylj/read-write-apart-demo.git

4 部署

4.1 准备一个kubernetes集群

在华为云购买一个集群即可。

4.2 安装helm

复制代码
cd /tmp
wget https://get.helm.sh/helm-v3.16.2-linux-amd64.tar.gz
tar xf helm-v3.16.2-linux-amd64.tar.gz
cd linux-amd64
/bin/cp -f helm /usr/bin/
helm env

helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo update

4.3 通过helm部署mysql 8.0主从集群

由于用于测试,数据库不需要持久化。

数据库root密码是:password,并自动创建名称叫demo的数据库。

复制代码
helm install mysql-ha-demo bitnami/mysql \
--set auth.rootPassword=my-secret-pw \
--set auth.database=demo \
--set auth.replicationUser=repuser \
--set auth.replicationPassword=reppassword \
--set primary.persistence.enabled=false \
--set secondary.persistence.enabled=false \
--set auth.rootPassword=password \
--set architecture=replication

4.4 部署JAVA程序

复制代码
git clone https://gitee.com/handsomeboylj/read-write-apart-demo.git
cd read-write-apart-demo
kubectl apply -f k8s-demo.yaml

JAVA程序的deployment有一个init容器,会对数据库进行初始化,有数据直接可用。

程序的接口如下:

读接口:

复制代码
GET /api/users/1

RESPONSE:
{
  "id": 1,
  "name": "Alice",
  "age": 25
}

写接口:

复制代码
POST /api/users
{"name":"test","age":30}

4.5 Ingress暴露JAVA程序

路由如下:

5 测试

5.1 读接口测试

在浏览器访问ELB的公网地址和接口路径:

JAVA程序中会打印日志:

复制代码
数据库切换成: slave

5.2 写接口测试

复制代码
curl -X POST -H "Content-Type: application/json" -d '{"name":"test","age":20}' http://公网EIP/api/users && echo

可见JAVA程序中会打印日志:

复制代码
数据库切换成: master

6 小结

本文介绍JAVA程序对mysql数据库进行读写分离的思路、代码实现,并且通过部署一套mysql集群和JAVA程序容器来进行实际测试,让人达到直观的效果。

相关推荐
源码_V_saaskw20 分钟前
JAVA图文短视频交友+自营商城系统源码支持小程序+Android+IOS+H5
java·微信小程序·小程序·uni-app·音视频·交友
超浪的晨30 分钟前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
双力臂4041 小时前
Spring Boot 单元测试进阶:JUnit5 + Mock测试与切片测试实战及覆盖率报告生成
java·spring boot·后端·单元测试
水瓶_bxt1 小时前
Centos安装HAProxy搭建Mysql高可用集群负载均衡
mysql·centos·负载均衡
♡喜欢做梦1 小时前
【MySQL】深入浅出事务:保证数据一致性的核心武器
数据库·mysql
遇见你的雩风1 小时前
MySQL的认识与基本操作
数据库·mysql
Edingbrugh.南空1 小时前
Aerospike与Redis深度对比:从架构到性能的全方位解析
java·开发语言·spring
dblens 数据库管理和开发工具1 小时前
MySQL新增字段DDL:锁表全解析、避坑指南与实战案例
数据库·mysql·dblens·dblens mysql·数据库连接管理
weixin_419658311 小时前
MySQL的基础操作
数据库·mysql
QQ_4376643142 小时前
C++11 右值引用 Lambda 表达式
java·开发语言·c++