博客
关于我
【kubernetes】kubernetes service 暴露端口到公网案例
阅读量:771 次
发布时间:2019-03-17

本文共 914 字,大约阅读时间需要 3 分钟。

在上一篇文章中,我们学习了在容器之间如何暴露端口,但外网是无法直接访问的,而Pod之间是可以互相访问的。现在,我们希望深入探讨如何将这些端口暴露给外部网络。

之前的设置

当前我们的集群设置如下:

[root@lcc-1 ~]# kubectl get deployment,pods,service -n dev -owide --show-labels
NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IM

这个命令显示了我们在dev命名空间中的部署、Pod和服务状态。接下来,我们需要配置服务(Service)以便外部可以访问。

目标

我们的目标是让外部网络能够访问服务内部的端口。为了实现这一点,我们需要使用Kubernetes中的服务(Service)概念。服务会创建一个Cluster IP,并配置网络防火墙(iptables)以便外部流量可以通过Load Balancer或NAT规则流入集群。

实施步骤

  • 创建服务:使用kubectl create命令创建一个新的服务,指定端口和目标端口。例如:
  • kubectl create -f service.yaml
    1. 查看服务详情:使用kubectl get service命令查看服务状态,确保状态为Running,并查看Cluster IP和端口配置。

    2. 外部访问:在外部网络中访问服务的Cluster IP。例如,使用浏览器访问http://<Cluster IP>:<端口>

    3. 防火墙配置:确保网络防火墙允许外部流量到达服务的Cluster IP和端口。如果需要,可以手动添加防火墙规则。

    4. 测试访问:使用curl或浏览器测试外部是否能够成功访问服务。

    5. 注意事项

      • Load Balancer:如果服务使用了Load Balancer,外部流量会自动分发到所有Pod。
      • NAT规则:如果集群没有直接接触互联网,可能需要配置NAT规则以允许外部流量到达Cluster IP。

      通过以上步骤,我们可以让外部网络访问服务内部的端口,实现更高效的资源利用和更好的外部访问体验。

    转载地址:http://lkvhz.baihongyu.com/

    你可能感兴趣的文章
    Node-RED中Button按钮组件和TextInput文字输入组件的使用
    查看>>
    vue3+Ts 项目打包时报错 ‘reactive‘is declared but its value is never read.及解决方法
    查看>>
    Node-RED中Slider滑杆和Numeric数值输入组件的使用
    查看>>
    Node-RED中Switch开关和Dropdown选择组件的使用
    查看>>
    Node-RED中使用exec节点实现调用外部exe程序
    查看>>
    Node-RED中使用function函式节点实现数值计算(相加计算)
    查看>>
    Node-RED中使用html节点爬取HTML网页资料之爬取Node-RED的最新版本
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用node-red-contrib-image-output节点实现图片预览
    查看>>
    Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中使用range范围节点实现从一个范围对应至另一个范围
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Vue3+elementplus实现图片上传下载(最强实践)
    查看>>
    Node-RED中将CSV数据写入txt文件并从文件中读取解析数据
    查看>>
    Node-RED中建立TCP服务端和客户端
    查看>>