k8s学习(二十八) K8s部署单节点mysql-statefulset方式

本文主要是介绍k8s学习(二十八) K8s部署单节点mysql-statefulset方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以下步骤的前提是已部署好storageclass,可参考https://blog.csdn.net/u011943534/article/details/100887530

1、下载mysql(已经下载好)

docker pull mysql:5.7
docker save -o mysql-5.7.tar mysql:5.7

2、导入镜像
将msyql-5.7.tar拷贝至K8s镜像服务器所在的节点

docker load -i mysql-5.7.tar
docker tag mysql:5.7 172.16.10.160:80/mysql:5.7
docker push 172.16.10.160:80/mysql:5.7
3、使用 kubectl apply -f mysql-server.yaml部署
---
apiVersion: apps/v1
kind: StatefulSet
metadata:name: mysqlnamespace: defaultlabels:app: mysqlversion: v1
spec:serviceName: "mysql"replicas: 1selector:matchLabels:app: mysqlversion: v1template:metadata:labels:app: mysqlversion: v1spec:containers:- name: mysqlimage: 172.16.10.160:80/mysql:5.7env:                        - name: MYSQL_ROOT_PASSWORDvalue: "root"ports:- containerPort: 3306volumeMounts:- name: mysql-datamountPath: /var/lib/mysql         volumeClaimTemplates:- metadata:name: mysql-dataannotations:volume.beta.kubernetes.io/storage-class: course-nfs-storagespec:accessModes: [ "ReadWriteOnce" ]resources:requests:storage: 5Gi
---
apiVersion: v1
kind: Service
metadata:name: mysqlnamespace: defaultlabels:app: mysqlservice: mysql
spec:ports:- port: 3306protocol: TCPtargetPort: 3306name: tcpclusterIP: Noneselector:app: mysql---
apiVersion: v1
kind: Service
metadata:name: mysql2namespace: defaultlabels:app: mysql2service: mysql2
spec:ports:- name: tcpprotocol: TCPtargetPort: 3306port: 3306nodePort: 31112type: NodePortselector:app: mysql

4、查看pod
在这里插入图片描述

5、外部使用31112端口访问
在这里插入图片描述

如果无需外部访问,将31112对应的service删除。
内部使用headless的service访问(ClusterIP:None的)

这篇关于k8s学习(二十八) K8s部署单节点mysql-statefulset方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1077589

相关文章

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分