一,暴露方法
1、hostNetwork:true 在pod中使用该配置,在这种Pod中运行的应用程序可以直接看到pod启动的主机的网络接口。
2、hostPort:直接将容器的端口与所调度的节点上的端口路由,这样用户就可以通过主机的IP来访问Pod了。
3、NodePort:是K8s里一个广泛应用的服务暴露方式。K8s中的service默认情况都是使用Cluster IP这种类型,会产生一个只能在内部访问的Cluster IP,如果想能够直接访问service,需要将service type修改为nodePort。同时给改service指定一个nodeport值(30000-32767),
4、LoadBalancer:只能在service上定义,是公有云提供的负载均衡器。
5、Ingress:ingress controller是由K8s管理的负载均衡容器,它的镜像包含一个nginx或HAProxy负载均衡器和一个控制器守护进程。
二,ingress部署
0. 概念:
通常情况下,Service 和 Pod 的 IP 仅可在集群内部访问, Ingress 就是为进入集群的请求提供路由规则的集合,ingress处于多个服务的前端,相当于智能路由或者集群入口。它允许你基于路径或者子域名来路由流量到后端服务。
ingress 控制器类型: Google Cloud Load Balance, Nginx , Contour , Istio等。
ingress 控制器插件: cert-manager
方法:如果想要应用这些规则,集群管理员需要部署一个ingress Controller,它监听Ingress和Service的变化,并根据规则配置负载均衡并提供访问入口。
1. 功能:
定义规则来允许进入集群的请求被转发到集群中对应服务上,从来实现服务暴漏。把集群内 Service 配置成外网能够访问的 URL。
2. ingress组成
1). Nginx 反向代理负载均衡器
2). Ingress Controller
跟 Kubernetes API 交互,实时获取后端 Service、Pod 等的变化,结合 Ingress 定义的规则生成配置,
更新上边的 Nginx 负载均衡器,并刷新使配置生效,来达到服务自动发现的作用。
3). Ingress
定义规则,通过它定义某个域名的请求过来之后转发到集群中指定的 Service。
可以通过 Yaml 文件定义,给一个或多个 Service 定义一个或多个 Ingress 规则。
3. 步骤
a. 创建ingress 控制器 ingress-nginx
wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/nginx-0.26.2/deploy/static/mandatory.yaml
wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/nginx-0.26.2/deploy/static/provider/baremetal/service-nodeport.yaml
docker pull quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.26.2 [下载比较慢,我的是国外服务器提前下载]
docker save quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.26.2 > nginx-ingress-controller.tar
传到k8s集群服务器
docker load < nginx-ingress-controlle
云计算之kubernetes服务暴露——ingress
最新推荐文章于 2025-08-16 13:14:45 发布

最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



