K8S-Service

概念:

Kubernetes 中 Service 是 将运行在一个或一组 Pod 上的网络应用程序公开为网络服务的方法。

服务类型:

可通过sepc.type属性设置服务类型
ClusterIP

通过集群的内部 IP 暴露服务,选择该值时服务只能够在集群内部访问。 这也是你没有为服务显式指定 type 时使用的默认值。 你可以使用 Ingress 或者 Gateway API 向公众暴露服务。
NodePort

通过每个节点上的 IP 和静态端口(NodePort)暴露服务。 为了让节点端口可用,Kubernetes 设置了集群 IP 地址,这等同于你请求 type: ClusterIP 的服务。
LoadBalancer

使用云提供商的负载均衡器向外部暴露服务。 Kubernetes 不直接提供负载均衡组件;你必须提供一个,或者将你的 Kubernetes 集群与云提供商集成。
ExternalName

将服务映射到 externalName 字段的内容(例如,映射到主名 api.foo.bar.example)。 该映射将集群的 DNS 服务器配置为返回具有该外部主机名值的 CNAME 记录。 无需创建任何类型代理。

Service和Endpoint 的区别

当创建service资源配置了selector时,endpoints 控制器会自动创建 endpoints 资源对象,该资源对象记录了 svc 和 pod 的一一对应关系。

demo

复制代码
apiVersion: v1
kind: Service
metadata:
   #指定service名称
   name: my-nginx-service
   #给service打上标签
   labels:
      app: nginx-svc 
#指定名称空间
   namespace: test
spec:
   selector:
#指定服务类型,ClusterIP,NodePort,LoadBalancer,ExternalName (默认为ClusterIP,集群内部ip,仅集群内部访问)
   type: ClusterIP
#通过标签选择pod   
      app: nginx
      version: 1.17.1
   ports:
      - name: http
#协议类型支持TCP,UDP
        protocol: TCP
        #暴露的端口
        port: 8888
        #pod端口
        targetPort: 80
      - name: https
        protocol: TCP
        port: 4431
        targetPort: 443  

相关命令

复制代码
 #查看test名称空间下service
 kubectl get svc -n [NameSpace]
 #查看service的详细信息
 kubectl describe svc [serviceName]
相关推荐
2401_840192272 分钟前
ZooKeeper 单机部署指南
分布式·zookeeper·云原生
江畔何人初6 分钟前
Linux 重要目录:/boot、/dev、/etc、/home
linux·运维·云原生
cyber_两只龙宝3 小时前
LVS-DR模式实验配置及原理详解
linux·网络·云原生·智能路由器·lvs·dr模式
学习3人组12 小时前
Docker 容器内文件↔本地双向复制备份
运维·docker·容器
学习3人组15 小时前
Docker 从本地Label-studio导入 tar 镜像包
运维·docker·容器
羑悻的小杀马特15 小时前
Docker-Android 容器化 + cpolar 穿透,完善异地调试
android·运维·docker·容器·cpolar
Y.O.U..15 小时前
Kubernetes-网络策略
网络·容器·kubernetes
lpfasd12316 小时前
Docker 使用注意事项:从磁盘爆满到安全实践的完整避坑指南
安全·docker·容器
勇气要爆发17 小时前
Docker+Ollama+LangChain:从零搭建企业级“隐私优先”本地 RAG 知识库 (附源码)
docker·容器·langchain·lora·rag·ollama·llama 3
水上冰石20 小时前
Kubernetes Ingress + TLS 故障排查全流程
云原生·容器·kubernetes