k8s如何对外访问service
在Kubernetes(K8s)中,可以通过以下几种方式对外访问Service:
1、NodePort:
这是最常见的对外访问Service的方式。通过将Service的类型设置为NodePort,Kubernetes会在每个Node上打开一个特定的端口,并将流量路由到Service的ClusterIP。外部系统可以通过访问任何Node的IP地址加上这个NodePort来访问Service。
2、LoadBalancer:
如果你的Kubernetes集群部署在支持LoadBalancer的云平台上,你可以将Service的类型设置为LoadBalancer。这将自动创建一个负载均衡器,并将外部流量路由到Service的ClusterIP。负载均衡器提供了一个稳定的IP地址,外部系统可以通过这个IP地址访问Service。
3、Ingress:
Ingress是Kubernetes的一个资源对象,用于配置集群外部的访问规则。通过Ingress,你可以定义路由规则,将外部流量路由到不同的Service。Ingress控制器(如Nginx Ingress Controller、Traefik等)负责处理实际的流量转发。要使用Ingress对外访问Service,你需要创建一个Ingress资源,并配置相应的路由规则。
下面是一个简单的示例,展示了如何使用Nginx Ingress Controller和Ingress资源来对外访问一个名为my-service的Service:
步骤 1:部署Nginx Ingress Controller
你可以使用以下命令来部署Nginx Ingress Controller:
bash复制代码
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/master/deploy/static/mandatory.yaml
步骤 2:创建Ingress资源
创建一个名为my-ingress.yaml的Ingress资源文件,内容如下:
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: my-ingress
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
spec:
rules:
- host: example.com
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: my-service
port:
number: 80
然后应用这个Ingress资源:
bash复制代码
kubectl apply -f my-ingress.yaml
步骤 3:配置DNS解析
在DNS管理界面中,将example.com解析到Ingress控制器的IP地址。
步骤 4:验证配置
通过浏览器访问http://example.com,你应该能够看到my-service的响应。
4、ExternalName:
Service的另一种类型是ExternalName,它允许你将Service映射到一个已存在的DNS域名。通过配置ExternalName类型的Service,你可以将外部流量直接路由到指定的域名,而不需要在Kubernetes集群内部创建额外的资源。
为了对外访问Service,你需要确保Kubernetes集群的网络策略允许外部流量进入集群,并且已经正确配置了相应的Service和访问规则。此外,还需要考虑安全性因素,如使用TLS加密、配置访问控制列表(ACLs)或限制访问的IP地址范围等。
选择哪种方式取决于你的具体需求、集群环境以及部署的云平台。在生产环境中,通常推荐使用LoadBalancer或Ingress来管理外部访问。
k8s如何对外访问service的更多相关文章
- k8s Nodeport方式下service访问,iptables处理逻辑(转)
原文 https://www.myf5.net/post/2330.htm k8s Nodeport方式下service访问,iptables处理逻辑 2017年07月11日 0条评论 976次阅读 ...
- 【转帖】k8s之Deployment与service
k8s之Deployment与service 2018年08月05日 18:11:00 xiyou_pen/pen 阅读数 5894 版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权 ...
- 外网如何访问 Service?- 每天5分钟玩转 Docker 容器技术(139)
除了 Cluster 内部可以访问 Service,很多情况我们也希望应用的 Service 能够暴露给 Cluster 外部.Kubernetes 提供了多种类型的 Service,默认是 Clus ...
- centos7下kubernetes(15。kubernetes-外网访问service)
kubernetes提供了多种类型的service,默认是cluster IP ClusterIP cluster内部IP对外提供服务,只有cluster内的节点和pod可访问,这是默认的servic ...
- k8s nodeport下访问请求未被分发到所有node的排错(转)
原文 https://www.myf5.net/post/2343.htm 现象: 从内部某个pod的容器里直接访问service的cluster地址,请求可以被正常转发到各个node上的pod里 但 ...
- Linux中如何开启8080端口供外界访问 和开启允许对外访问的端口8000
举例: 开放10000端口的解决步骤如下: 1.修改/etc/sysconfig/iptables文件,增加如下一行: -A INPUT -m state --state NEW -m tcp -p ...
- 外网如何访问 Service?【转】
除了 Cluster 内部可以访问 Service,很多情况我们也希望应用的 Service 能够暴露给 Cluster 外部.Kubernetes 提供了多种类型的 Service,默认是 Clus ...
- LINUX开启允许对外访问的网络端口
LINUX开启允许对外访问的网络端口 LINUX通过下面的命令可以开启允许对外访问的网络端口: /sbin/iptables -I INPUT -p tcp --dport 8000 -j ACCE ...
- 如何访问 Service?- 每天5分钟玩转 Docker 容器技术(99)
前面我们已经学习了如何部署 service,也验证了 swarm 的 failover 特性.不过截止到现在,有一个重要问题还没有涉及:如何访问 service?这就是本节要讨论的问题. 为了便于分析 ...
- DNS 访问 Service - 每天5分钟玩转 Docker 容器技术(138)
在 Cluster 中,除了可以通过 Cluster IP 访问 Service,Kubernetes 还提供了更为方便的 DNS 访问. kubeadm 部署时会默认安装 kube-dns 组件. ...
随机推荐
- .NetCore 三种生命周期注入方式
.NetCore彻底诠释了"万物皆可注入"这句话的含义,在.NetCore中到处可见注入的使用.因此core中也提供了三种注入方式的使用,分别是: AddTransient:每次请 ...
- 在K8S中,Pod亲和性概念是什么?
在Kubernetes(简称K8S)中,Pod亲和性和反亲和性(Affinity and Anti-Affinity)是集群调度策略的重要组成部分,它们用于控制Pod如何与节点或其他Pod相对应地放置 ...
- 完蛋,我被offer包围了|秋招自救指南
前言 白泽时隔8年终于记起了b站的密码,这篇文章的视频讲解版已经上传,出镜怪不好意思的,后面写技术文章也会同步用视频的方式讲解,期待您的关注. 公众号:白泽talk,交流群:622383022. 大家 ...
- 深入浅出 Application Insights--学习笔记
摘要 介绍如何将 Application Insights 用于生产上实践,并透过它发现/诊断问题.同时也会介绍如何将 Application Insighs 与其他体系相集成实现 Devops(与发 ...
- kafka-Kafka3.4版本创建topic出现zookeeper is not a recognized option
问题描述:在linux云服务器上搭建了一套kafka3.0集群,然后按照以前的创建topic指令: ./kafka-topics.sh --zookeeper hadoop01:2181,hadoop ...
- 【译】我为 .NET 开发人员准备的 2023 年 Visual Studio 10 大新功能
原文 | James Montemagno 翻译 | 郑子铭 Visual Studio 2022 在 2023 年发布了许多令人难以置信的功能,为 .NET 开发人员提供了大量新工具来提高他们的工作 ...
- CF327C Magic Five 题解
题目传送门 前置知识 等比数列求和公式 | 乘法逆元 解法 设 \(lena\) 表示 \(a\) 的长度. 首先,若一个数能被 \(5\) 整除,则该数的末尾一定为 \(0\) 或 \(5\).故考 ...
- NC14402 求最大值
题目链接 题目 题目描述 给出一个序列,你的任务是求每次操作之后序列中 (a[j]-a[i])/(j-i)[1<=i<j<=n]的最大值. 操作次数有Q次,每次操作需要将位子p处的数 ...
- Java Socket设置timeout几种常用方式总结
原文链接:https://my.oschina.net/shipley/blog/715196 最近碰到读取第三方提供socket接口需要设置超时时间问题,特此记录一下.原文中有几处拼写错误顺便改掉了 ...
- Git 分支管理参考模型
一个值得参考的Git分支管理模型如下: master 生产主分支,发布到生产环境使用这个分支,由hotfix或者release分支合并过来,不直接提交代码. release 预发布分支, 基于feat ...