k8s集群内的pod连接集群外部的mysql, k8s集群内部服务如何连接集群外部mysql? 一文搞明白
一、为什么不将mysql服务部署到k8s集群中使用呢?
1.有状态服务在K8s中的管理比较复杂,特别是持久化存储的问题。虽然K8s有StatefulSet和PV/PVC,但配置和维护起来需要更多工作,同时以下问题仍需解决:-存储可靠性:如果使用本地存储(如 hostPath),节点故障可能导致数据丢失;若用网络存储(如云盘),需确保性能和延迟满足数据库需求。 -备份与恢复:需额外配置定期备份工具(如 mysqldump、Percona XtraBackup),并验证恢复流程的可靠性。-数据库版本升级或迁移(如从 MySQL 5.7 到 8.0)在 Kubernetes 中可能涉及复杂的 StatefulSet 滚动更新策略,风险较高。2.网络和性能问题,比如存储I/O延迟,可能影响数据库性能。若应用和数据库部署在同一集群内,虽然网络延迟较低,但多副本数据库(如主从架构)跨节点通信可能引入额外延迟。高可用性和数据一致性也是挑战,需要配置主从复制、故障转移等。
二、什么情况下可以考虑在 Kubernetes 中部署 MySQL?
1.开发或测试环境快速迭代需求:在开发环境中,使用 Kubernetes 部署 MySQL 可以快速启停实例,配合 CI/CD 流水线实现自动化测试。
低成本验证架构:验证 Kubernetes 有状态服务管理能力时,可通过轻量级 MySQL 实例进行技术预研。2.本地化部署需求:在边缘节点(如工厂、物联网设备)中,若无法连接云端数据库,可在本地 Kubernetes 集群中部署 MySQL。
数据主权合规:某些行业要求数据必须存储在本地,此时需在私有 Kubernetes 集群中运行数据库。3.特殊版本或插件依赖:如果业务依赖特定 MySQL 版本或自定义插件(如自研的存储引擎),且云服务不兼容,可选择自建。
4.与 Kubernetes 生态深度集成:例如,需要将数据库日志直接接入集群内的 Elasticsearch,或通过 Service Mesh(如 Istio)实现数据库流量治理。
解决方案:在 Kubernetes 集群内部接入外部 MySQL 数据库,可以通过以下步骤实现。这里提供两种常见方法:使用 Service 资源直接指向外部地址或通过 Endpoints 手动配置。
实验开始前注意:
只要宿主机可以通讯,那么pod内也是可以直接通过宿主机的IP访问集群之外的服务。因为虽然是pod发出的请求,实际上经过转发,出去的时候是以宿主机的IP进行访问的,所以我们授权的时候,保证运行pod的宿主机能登录数据库就行了,并不是对pod的IP进行授权。
方法 1:使用 ExternalName 类型的 Service
适用于外部 MySQL 有固定域名的情况(如云服务商提供的数据库域名)。
1. 创建 ExternalName Service
[root@master ~]# mysql-external.yaml
apiVersion: v1
kind: Service
metadata:name: mysql-external # 集群内通过该名称访问
spec:type: ExternalNameexternalName: your-mysql-hostname.example.com # 外部MySQL的域名如:阿里云的RDSports:- port: 3306 # Service 暴露的端口targetPort: 3306 # 外部MySQL的实际端口
应用配置:
[root@master ~]# kubectl apply -f mysql-external.yaml
2. 应用程序连接方式
在应用中配置数据库主机为 mysql-external(Service 名称),端口为 3306。Kubernetes DNS 会自动将 mysql-external 解析为外部域名。
方法 2:手动指定 Endpoints(适用于IP直连)
如果外部 MySQL 是固定 IP 且无域名,可以手动创建 Service 和 Endpoints。
1.首先先登陆外部数据库创建一个普通用户并相应的授权设置为允许远程登陆。
[root@mysql-master ~]# mysql -uroot -p'Mysql@123!'
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.7.44-log MySQL Community Server (GPL)Copyright (c) 2000, 2023, Oracle and/or its affiliates.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> grant all on *.* to jack@'%' identified by 'Mysql@1233!';
Query OK, 0 rows affected, 1 warning (0.03 sec)mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)mysql>
在k8s集群中
1. 创建 Service 和 Endpoints
[root@master ~]# mkdir test/mysql -p
[root@master ~]# cd test/mysql/
[root@master mysql]# kubectl create ns test #创建一个名称空间
[root@master mysql]# cat mysql-external-svc.yml
apiVersion: v1
kind: Service
metadata:name: mysql-externalnamespace: test
spec:ports:- port: 3306targetPort: 3306clusterIP: None #表示这是一个 headless service,直接通过 Endpoint 连接
---
apiVersion: v1
kind: Endpoints
metadata:namespace: testname: mysql-external #此名字需要于service中定义的name字段一致
subsets:
- addresses:- ip: 192.168.209.141 #定义外部mysql机器的ip地址ports:- port: 3306
当我们创建headless service时也会为service分配域名
service_name.namespace.svc.cluster.local我们可以通过dig或者nslookup 命令来解析查看dns是否解析成功。dns 为coredns负责解析
应用配置:
[root@master mysql]# kubectl apply -f mysql-external-svc.yml
service/mysql-external created
endpoints/mysql-external created
[root@master mysql]# kubectl get svc,ep -n test
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/mysql-external ClusterIP None <none> 3306/TCP 4m16sNAME ENDPOINTS AGE
endpoints/mysql-external 192.168.209.141:3306 4m16s
2. 应用程序连接方式
在代码中配置数据库主机为 mysql-external(Service名称),端口 3306。
关键注意事项
1. 网络连通性
-
确保集群节点能访问外部MySQL:检查防火墙、安全组是否放行 Kubernetes 节点到 MySQL 的
3306端口。 -
测试连接:
1.创建一个centos的pod [root@master mysql]# cat test-mysql.yml apiVersion: v1 kind: Pod metadata:name: centos7-podnamespace: test spec:nodeName: node-1containers:- name: centos7-containerimage: registry.cn-hangzhou.aliyuncs.com/testpm-k8s/centos:7command:- sleep- "3600"[root@master mysql]# kubectl get pod -n test NAME READY STATUS RESTARTS AGE centos7-pod 1/1 Running 0 7s[root@master mysql]# kubectl exec -it centos7-pod -n test -- /bin/bash [root@centos7-pod /]# yum install -y mysql [root@centos7-pod /]# mysql -ujack -p'Mysql@1233!' -h mysql-external Welcome to the MariaDB monitor. Commands end with ; or \g. Your MySQL connection id is 14 Server version: 5.7.44-log MySQL Community Server (GPL)Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.MySQL [(none)]> \q Bye在pod里面ping service的域名 [root@centos7-pod /]# ping mysql-external PING mysql-external.test.svc.cluster.local (192.168.209.141) 56(84) bytes of data. 64 bytes from 192-168-209-141.mysql-external.test.svc.cluster.local (192.168.209.141): icmp_seq=1 ttl=63 time=0.669 ms 64 bytes from 192-168-209-141.mysql-external.test.svc.cluster.local (192.168.209.141): icmp_seq=2 ttl=63 time=1.06 ms通过ping service的域名可以看到返回的值为mysql宿主机的ip。
2. 数据库权限
确保 MySQL 用户允许从 Kubernetes Pod 的 IP 范围连接。例如:
CREATE USER 'jack'@'%' IDENTIFIED BY 'Mysql@1233!';
GRANT ALL PRIVILEGES ON *.* TO 'jack'@'%';
总结
- 推荐方法:优先使用
ExternalNameService(有域名时)或手动配置 Endpoints(直接使用 IP)。 - 调试工具:通过临时 Pod 执行
telnet或mysql-client命令验证连接。 - 安全实践:始终通过 Secret 管理凭证,并启用 SSL 加密敏感数据传输。
通过以上步骤,Kubernetes 集群内的应用即可安全、稳定地访问外部 MySQL 数据库。
相关文章:
k8s集群内的pod连接集群外部的mysql, k8s集群内部服务如何连接集群外部mysql? 一文搞明白
一、为什么不将mysql服务部署到k8s集群中使用呢? 1.有状态服务在K8s中的管理比较复杂,特别是持久化存储的问题。虽然K8s有StatefulSet和PV/PVC,但配置和维护起来需要更多工作,同时以下问题仍需解决:-存储可靠性:如果使…...
C#使用Semantic Kernel:接入本地deepseek-r1
安装Ollama 1.下载Ollama 访问Ollama官网(https://ollama.com),选择适合你操作系统的版本进行下载。 对于Linux用户,可以通过以下命令安装: curl -fsSL https://ollama.com/install.sh | sudo bash sudo system…...
【算法】直接插入排序、折半插入排序、希尔排序
1 直接插入排序 时间复杂度:O(N^2) 空间复杂度:O(1) 稳定性:稳定 元素集合越接近有序,直接插入排序算法的时间效率越高 1.1直接插入排序思想 把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中ÿ…...
使用API有效率地管理Dynadot域名,为域名部署DNS安全拓展(DNSSEC)
关于Dynadot Dynadot是通过ICANN认证的域名注册商,自2002年成立以来,服务于全球108个国家和地区的客户,为数以万计的客户提供简洁,优惠,安全的域名注册以及管理服务。 Dynadot平台操作教程索引(包括域名邮…...
【排版教程】如何在Word/WPS中优雅的插入参考文献
材料展示 随便选取一段综述内容,以及对应的参考文献,如下图所示: 1 参考文献编辑 首先对参考文献部分进行编辑,将其设置自动编号 在段落中,选择悬挂缩进 在编号中,设置自定义编号,然后按照…...
神经形态视觉的实时动态避障系统:突破传统SLAM的响应延迟瓶颈
引言:机器人感知的实时性挑战 斯坦福机器人实验室采用异步脉冲神经网络处理DVS事件相机数据后,动态障碍物响应延迟从34ms降至0.9ms。在20m复杂场景避障测试中,基于神经形态芯片的路径规划系统将SLAM更新频率提升至10kHz,较传统GP…...
python绘图之密集散点图
密集散点图主要目的是生成一个可视化图表,展示 insurance 数据集中 bmi(身体质量指数)和 charges(医疗费用)之间的关系,并通过不同的维度对数据进行分组和区分,以便更清晰地观察数据的分布和特征…...
Linux操作系统4-进程间通信5(共享内存实现两个进程通信)
上篇文章:Linux操作系统4-进程间通信4(共享内存原理,创建,查看,命令)-CSDN博客 本篇Gitee仓库:myLerningCode/l24 橘子真甜/Linux操作系统与网络编程学习 - 码云 - 开源中国 (gitee.com) 本篇重…...
sam2 windows 编译安装
目录 1. pip install sam2 2. 编译安装 1. pip install sam2 运行报错: cannot import name _C from sam2 (E:\project\smpl\render_blender\linux\GroundedSAM2_SMPL\sam2\__init__.py) 2. 编译安装 cd E:\project\sam2\sam2-main set DISTUTILS_USE_SDK1 py…...
RFID测温技术:电力设备安全监测的新利器
在当今高度依赖电力的现代化社会中,稳定且可靠的电力供应是社会运转的基石。电力设备作为电力系统的关键核心,其运行状态直接关乎电力供应的品质。然而,电力设备长期运行过程中,受到诸如过载、接触不良以及环境因素等多重影响&…...
(一)趣学设计模式 之 单例模式!
目录 一、啥是单例模式?二、为什么要用单例模式?三、单例模式怎么实现?1. 饿汉式:先下手为强! 😈2. 懒汉式:用的时候再创建! 😴3. 枚举:最简单最安全的单例&a…...
自动化办公|xlwings生成图表
在日常的数据分析和报告生成中,Excel图表是一个非常重要的工具。它能够帮助我们直观地展示数据,发现数据中的规律和趋势。然而,手动创建和调整图表往往耗时且容易出错。幸运的是,借助Python的xlwings库,我们可以自动化…...
Docker基于Ollama本地部署大语言模型
一、Ollama介绍 Ollama 是一个开源的大型语言模型(LLM)平台,旨在简化大型语言模型在本地环境中的运行、管理和交互。通过Ollama,用户可以轻松加载和使用各种预训练的语言模型,执行诸如文本生成、翻译、代码编写、问答…...
Pytorch实现之GIEGAN(生成器信息增强GAN)训练自己的数据集
简介 简介:在训练数据样本之前首先利用VAE来推断潜在空间中不同类的分布,用于后续的训练,并使用它来初始化GAN。与ACGAN和BAGAN不同的是,提出的GIEGAN有一个分类器结构,这个分类器主要判断生成的图像或者样本图像属于哪个类,而鉴别器仅判断图像是来自于生成器还是真实样…...
centos9安装k8s集群
以下是基于CentOS Stream 9的Kubernetes 1.28.2完整安装流程(containerd版): 一、系统初始化(所有节点执行) # 关闭防火墙 systemctl disable --now firewalld# 关闭SELinux sed -i "s/SELINUXenforcing/SELINU…...
pytest下allure
import pytestdef test_case01():用例01~print(用例01)class Test_mokuai01:def test_case02(self):用例02~print(用例02)if __name____main__:#pytest.main([-vs,test_sample-2.py])pytest.main([-vs,test_sample-2.py,--allure-dir,./result2])#生成allure报告,参…...
JVM预热
阿里电商平台每年的各种大促活动,对于Java技术来说,其中重要一个操作环节就是预热操作。 目录 预热是什么?为什么要预热? java 程序不预热和预热的调用对比 预热是什么? 预热是指,在 JVM 启动后࿰…...
【JavaWeb12】数据交换与异步请求:JSON与Ajax的绝妙搭配是否塑造了Web的交互革命?
文章目录 🌍一. 数据交换--JSON❄️1. JSON介绍❄️2. JSON 快速入门❄️3. JSON 对象和字符串对象转换❄️4. JSON 在 java 中使用❄️5. 代码演示 🌍二. 异步请求--Ajax❄️1. 基本介绍❄️2. JavaScript 原生 Ajax 请求❄️3. JQuery 的 Ajax 请求 &a…...
Ubuntu 查看mysql用户和数据库
在Ubuntu系统中,你可以使用以下MySQL命令来查看用户和数据库的信息。请确保你已经安装了MySQL服务器,并且你具有足够的权限(如root用户权限)来执行这些命令。 查看所有数据库 要查看MySQL服务器上的所有数据库,可以使…...
数据库服务器和应用服务器的区别是什么?
在当今的互联网社会中,各个行业中的业务都离不来网络科技,而作为互联网基础设施的服务器,受到了各大行业的广泛应用,同时根据所承担职责的不同,可以将服务器分为数据库服务器和应用服务器,本文就来概括一下…...
初级银行从业考试真题
2023 年 6 月初级银行从业考试真题 法律法规 单选题 1.按照《中华人民共和国反洗钱法》的规定,金融机构所建立的客户身份资料和客户交易信息在业务关系或交易结束后至少 保存期限为()年。 A.5 B.3 C.10 D.2 参考答案:A 2.物价稳定是要保持()的大体稳定,避免出现高…...
普通转录组RNASeq生物信息流程
探序基因肿瘤研究院 整理 比对工具:HISAT2,下载源代码编译安装或者二进制文件 定量工具:feactureCounts,下载地址:The Subread package 参考基因组:NCBI的GCF_000001405.40_GRCh38.p14_genomic.fna.g…...
nginx容器配置fastapi服务失败
问题描述: Linux虚拟机中启动了一个fastapi服务器(8000端口),希望能通过nginx容器设置代理使得前端代码可以调用这个接口,但是访问时报错(状态码:502)。nginx配置如下: l…...
网页制作06-html,css,javascript初认识のhtml如何建立超链接
超链接有外部链接、电子邮件链接、锚点链接、空链接、脚本链接 一、内部链接 与自身网站页面有关的链接被称为内部链接 1、创建内部链接 1)语法: <a href"链接地址"> …… </a> 2)举例应用: 3…...
代码讲解系列-CV(七)——前沿论文复现
文章目录 一、论文速览1.1 确定baseline1.2 DepthMaster: Taming Diffusion Models for Monocular Depth Estimation 二、数据环境搭建2.1 环境搭建2.2 数据权重 三、推理debug3.1 单图推理3.2 数据集验证 四、模型训练4.1 数据读取4.2 训练流程 五、作业 一、论文速览 1.1 确…...
3DGS(三维高斯散射)与SLAM技术结合的应用
3DGS(三维高斯散射)与SLAM(即时定位与地图构建)技术的结合,为动态环境感知、高效场景建模与实时渲染提供了新的可能性。以下从技术融合原理、应用场景、优势挑战及典型案例展开分析: 一、核心融合原理 1. …...
数据库面试知识点总结
目录 1. MySQL 基础题1.1 执行⼀条 select / update 语句,在 MySQL 中发生了什么?1.2 MySQL 一行记录是怎么存储的? 2. 三大范式3. 数据库引擎3.1 Innodb3.2 MyISAM 4. 数据库索引4.1 索引分类4.2 索引优缺点4.3 索引使用场景4.4 优化索引方法…...
1.25作业
1easytornado SSTI——tornado模板 hints.txt:在/fllllllllllllag里;计算filehash的方法(需要cookie_secret,对filename进行md5拼接再第二次md5) ?filename/hints.txt&filehash{ {2*3}},跳转到另一个页面 存在且…...
Power Query M函数
文章目录 三、PQ高阶技能:M函数3.1 M函数基本概念3.1.1 表达式和值3.1.2 计算3.1.3 运算符3.1.4 函数3.1.5 元数据3.1.6 Let 表达式3.1.6 If 表达式3.1.7 Error 3.2 自定义M函数3.2.1 语法3.2.2 调用定义好的自定义函数3.2.3 直接调用自定义函数3.2.4 自定义函数&am…...
python argparse 解析命令行参数
可选参数 带 - 或者 -- 的参数都是可选参数,如果命令行不输入,得到的结果是 None 参数名只能使用下划线,不能使用中划线 default: 设置默认值 action: 默认是 store 方法,常用的是 store_true 命令行出…...
