当前位置: 首页 > news >正文

mysql一主多从 k8s部署实际案例

一、Kubernetes配置(MySQL主从集群)

  1. 主库StatefulSet配置(master-mysql.yaml):
apiVersion: apps/v1
kind: StatefulSet
metadata:name: mysql-master
spec:serviceName: "mysql-master"replicas: 1selector:matchLabels:app: mysql-mastertemplate:metadata:labels:app: mysql-masterspec:containers:- name: mysqlimage: mysql:8.0env:- name: MYSQL_ROOT_PASSWORDvalue: "root123"- name: MYSQL_DATABASEvalue: "app_db"# 主库配置参数args:- "--server-id=1"- "--log-bin=mysql-bin"- "--binlog_do_db=app_db"- "--gtid-mode=ON"- "--enforce-gtid-consistency=ON"ports:- containerPort: 3306volumeMounts:- name: mysql-datamountPath: /var/lib/mysqlvolumeClaimTemplates:- metadata:name: mysql-dataspec:accessModes: [ "ReadWriteOnce" ]storageClassName: "standard"resources:requests:storage: 20Gi
  1. 从库StatefulSet配置(slave-mysql.yaml):
apiVersion: apps/v1
kind: StatefulSet
metadata:name: mysql-slave
spec:serviceName: "mysql-slave"replicas: 2  # 两个从库实例selector:matchLabels:app: mysql-slavetemplate:metadata:labels:app: mysql-slavespec:containers:- name: mysqlimage: mysql:8.0env:- name: MYSQL_ROOT_PASSWORDvalue: "root123"# 从库配置参数args:- "--server-id=$HOSTNAME_SLICE"  # 动态生成唯一server-id- "--relay-log=mysql-relay"- "--read-only=ON"- "--gtid-mode=ON"- "--enforce-gtid-consistency=ON"- "--skip-slave-start"  # 等待手动配置主从复制ports:- containerPort: 3306volumeMounts:- name: mysql-datamountPath: /var/lib/mysqlvolumeClaimTemplates:- metadata:name: mysql-dataspec:accessModes: [ "ReadWriteOnce" ]storageClassName: "standard"resources:requests:storage: 20Gi

二、Java读写分离实现(Spring Boot示例)

  1. 数据源配置(application.yml):
spring:datasource:master:jdbc-url: jdbc:mysql://mysql-master:3306/app_dbusername: rootpassword: root123driver-class-name: com.mysql.cj.jdbc.Driverslaves:- jdbc-url: jdbc:mysql://mysql-slave-0:3306/app_dbusername: rootpassword: root123- jdbc-url: jdbc:mysql://mysql-slave-1:3306/app_dbusername: rootpassword: root123
  1. 动态数据源配置类:
/*** 动态数据源配置*/
@Configuration
@EnableTransactionManagement
@MapperScan("com.example.mapper")
public class DynamicDataSourceConfig {@Bean@ConfigurationProperties(prefix = "spring.datasource.master")public DataSource masterDataSource() {return DataSourceBuilder.create().build();}@Beanpublic DataSource slaveDataSource() {// 创建从库数据源列表List<DataSource> slaves = new ArrayList<>();// 这里需要根据实际配置动态加载从库数据源// ...(具体实现根据配置加载多个从库)// 负载均衡策略(轮询)return new LoadBalancedDataSource(slaves);}@Beanpublic DataSource dynamicDataSource(@Qualifier("masterDataSource") DataSource master,@Qualifier("slaveDataSource") DataSource slave) {DynamicDataSource dynamicDataSource = new DynamicDataSource();Map<Object, Object> targetDataSources = new HashMap<>();targetDataSources.put("master", master);targetDataSources.put("slave", slave);dynamicDataSource.setTargetDataSources(targetDataSources);dynamicDataSource.setDefaultTargetDataSource(master);return dynamicDataSource;}
}
  1. 数据源路由实现:
/*** 动态数据源路由器*/
public class DynamicDataSource extends AbstractRoutingDataSource {private static final ThreadLocal<String> CONTEXT_HOLDER = new ThreadLocal<>();@Overrideprotected Object determineCurrentLookupKey() {return CONTEXT_HOLDER.get();}public static void setDataSource(String dataSource) {CONTEXT_HOLDER.set(dataSource);}public static void clearDataSource() {CONTEXT_HOLDER.remove();}
}
  1. 自定义注解实现读写分离:
/*** 数据源选择注解*/
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface DataSource {DataSourceType value() default DataSourceType.MASTER;
}public enum DataSourceType {MASTER, SLAVE
}
  1. AOP切面实现:
@Aspect
@Component
public class DataSourceAspect {@Before("@annotation(dataSource)")public void beforeSwitchDS(JoinPoint point, DataSource dataSource) {DataSourceType value = dataSource.value();if (value == DataSourceType.MASTER) {DynamicDataSource.setDataSource("master");} else {DynamicDataSource.setDataSource("slave");}}@Before("execution(* com.example.service..*.save*(..)) || " +"execution(* com.example.service..*.update*(..)) || " +"execution(* com.example.service..*.delete*(..))")public void writeOperations() {DynamicDataSource.setDataSource("master");}@AfterReturning("execution(* com.example.service..*.*(..))")public void afterReturning() {DynamicDataSource.clearDataSource();}
}

三、部署说明

  1. 集群初始化步骤:
# 部署主库
kubectl apply -f kubernetes/mysql/master-mysql.yaml# 等待主库启动完成后部署从库
kubectl apply -f kubernetes/mysql/slave-mysql.yaml# 验证Pod状态
kubectl get pods -l app=mysql-master
kubectl get pods -l app=mysql-slave
  1. 主从复制配置(在从库Pod中执行):
# 进入从库容器
kubectl exec -it mysql-slave-0 -- bash# 在MySQL中执行
CHANGE MASTER TO
MASTER_HOST='mysql-master',
MASTER_USER='root',
MASTER_PASSWORD='root123',
MASTER_AUTO_POSITION=1;START SLAVE;

四、架构特点说明

  1. 数据一致性保障:
  • 使用GTID实现事务一致性
  • 半同步复制配置(需在MySQL配置中额外添加)
  • 自动故障转移机制(建议配合k8s探针使用)
  1. 读写分离策略:
  • 写操作强制路由主库
  • 读操作自动负载均衡
  • 事务中强制使用主库
  1. 扩展性设计:
  • 从库数量可动态调整(修改StatefulSet replicas)
  • 自动水平扩展从库集群
  • 支持多可用区部署(需配置亲和性策略)

注意事项:

  1. 生产环境需配置Secret管理数据库密码
  2. 建议添加MySQL连接池配置(如HikariCP)
  3. 需要配置合适的持久化存储方案
  4. 建议添加监控和报警机制(Prometheus+Granafa)

相关文章:

  • ssm学习笔记(尚硅谷) day1
  • 从融智学视角对决策态度进行定理级提炼,结合三标准数学建模
  • 微服务测试困境?Parasoft SOAtest的自动化、虚拟化与智能分析来袭!
  • 代码随想录打卡|Day51 图论(dijkstra(堆优化版)精讲、Bellman_ford 算法精讲)
  • 【前端】Twemoji(Twitter Emoji)
  • LeetCode 215:数组中的第K个最大元素 - 两种高效解法详解
  • 力扣-最长回文子串
  • HTB-Planning
  • PnP(Perspective-n-Point)算法 | 用于求解已知n个3D点及其对应2D投影点的相机位姿
  • Python基础教程:控制流与函数入门 - 第4-6天
  • 【网络入侵检测】基于Suricata源码分析FlowWorker实现
  • 智能仓储落地:机器人如何通过自动化减少仓库操作失误?
  • DeepSeek - 尝试一下GitHub Models中的DeepSeek
  • EasyRTC音视频实时通话助力微信小程序:打造低延迟、高可靠的VoIP端到端呼叫解决方案
  • 【ConvLSTM第二期】模拟视频帧的时序建模(Python代码实现)
  • Text-to-SQL评估体系:从Spider 1.0数据集到2.0框架的跨越与革新
  • HOW - 简历和求职面试宝典(八)
  • 【春秋云镜】CVE-2022-26965 靶场writeup
  • 江西某石灰石矿边坡自动化监测
  • 【Hive 运维实战】一键管理 Hive 服务:Metastore 与 HiveServer2 控制脚本开发与实践
  • 贵阳市做网站电话/在线磁力搜索引擎
  • 程序员自己做网站怎么赚钱/google关键词搜索技巧
  • 安徽省建设厅网站怎么进不去/百度推广下载安装
  • 企业网站管理系统怎么用/aso网站
  • 国外简约企业网站/网络推广渠道都有哪些
  • 做外贸无网站如何做/建设网站制作