登录
首页 >  数据库 >  MySQL

为什么使用 ClusterIP + Ingress 无法从外部访问内部 MySQL,而使用 NodePort 却可以?

时间:2024-11-30 13:52:08 481浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《为什么使用 ClusterIP + Ingress 无法从外部访问内部 MySQL,而使用 NodePort 却可以?》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

为什么使用 ClusterIP + Ingress 无法从外部访问内部 MySQL,而使用 NodePort 却可以?

k8s 中使用 ClusterIP + Ingress 从外部访问内部 MySQL

你在 minikube 环境中使用 ClusterIP 和 Ingress 配置 MySQL 集群。但是,你无法从外部访问 MySQL,而 NodePort 却可以工作。这是因为:

使用 ClusterIP + Ingress

  • ClusterIP 服务创建了一个内部 IP,仅集群内部的可访问。
  • Ingress 充当集群外部的入口,将外部流量路由到 ClusterIP 服务。
  • 默认情况下,Ingress 只能转发 HTTP/HTTPS 流量。

因此,使用 ClusterIP + Ingress 从外部访问 MySQL 需要额外配置,例如:

  • 通过 Service 资源中的 annotations 字段启用 TCP 流量代理。
  • 创建一个新的 Ingress,以及一个监听 TCP 端口的 IngressClass 和 Service。

使用 NodePort

  • NodePort 服务将集群中的 3306 端口映射到宿主机上的 30001 端口。
  • 这允许通过 NodePort 访问 MySQL,无需额外配置。

在你的特定情况下,你使用 NodePort 访问了 MySQL,因为你通过宿主机的 IP 和端口直接访问,而没有使用 Ingress。

参考:

  • [使用 Ingress 公开服务](https://kubernetes.io/docs/ingress-nginx/ingress-exposing-tcp-udp-services/)
  • [使用 NodePort 服务](https://kubernetes.io/docs/concepts/services-networking/service/#nodeport)

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《为什么使用 ClusterIP + Ingress 无法从外部访问内部 MySQL,而使用 NodePort 却可以?》文章吧,也可关注golang学习网公众号了解相关技术文章。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>