k8s集群-7 service

工作负载的应用是如何暴露出去的 解决访问问题

Service可以看作是一组提供相同服务的Pod对外的访问接口。借助Service,应用可以方便地实现服务发现和负载均衡。

service默认只支持4层负载均衡能力,没有7层功能。(可以通过Ingress实现)

service的类型:

ClusterlP:默认值,k8s系统给service自动分配的虚拟IP,只能在集群内部访问。NodePort: 将Service通过指定的Node上的端口暴露给外部,访问任意一个NodelP:nodePort都将路由到ClusterIP.LoadBalancer:在 NodePort 的基础上,借助 cloud provider 创建一个外部的负载均衡器,并将请求转发到 <NodelP>:NodePort,此模式只能在云服务器上使用。ExternalName:将服务通过DNS CNAME记录方式转发到指定的域名(通过spec.externIName 设定)。

作用就是 不管在集群内还是集群外 都可以访问pod 上面的应用

并且对集群内的应用pod 自动发现和负载均衡

service默认支持四层负载均衡 七层需要 inggress 来支持

Service 是由 kube-proxy 组件,加上iptables 来共同实现的

kube-proxy 通过 iptables 处理 Service 的过程,需要在宿主机上设置相当多的iptables 规则,如果宿主机有大量的Pod,不断刷新iptables规则,会消耗大量的CPU资源。

IPVS模式的service,可以使K8s集群支持更多量级的Pod.

必须要有proxy 如果跨主机网络通信 还需要flannel 节点 然后在结合每个节点上的 iptables 从而再实现负载均衡

默认类型是ClusterIP 不指定就是 CLusterIP

默认使用iptables 调度 iptables 算法是随机的 推荐使用 lvs

ipvs 模式 LVS内核调度 算法更强大 性能更好

减少在刷 iptables 所带来的消耗

修改proxy配置

重启pod

切换ipvs模式后,kube-proxy会在宿主机上添加一个虚拟网卡:kube-ipvs0,并分配service IP

==============================

Nodeport

nodeport在集群节点上绑定端口,一个端口对应一个服务

=============================

headless

headless模式不分配vip

这种类型也是 一种特殊的clusterIP 类型 cluserIp 仅限于集群内访问

headless通过svc名称访问,由集群内dns提供解析

集群内直接使用service名称访问

仅限于集群内

============================

从外部访问的第二种方式 适用于 k8S 服务

默认无法分配外部访问IP

LoadBalancer模式适用云平台,裸金属环境需要安装metallb提供支持

loadBlabcer -> nodeport -> clusterip -> pod

官网:https://metallb.universe.tf/installation/

metallb

下载部署文件

修改文件中镜像地址,与harbor仓库路径保持一致

拉取镜像

打标签

上传镜像

部署服务

配置分配地址段

相关推荐
程序员老邢2 分钟前
【人生底稿・番外篇 05】我的电影江湖:从录像带时代,到港片陪伴的青春岁月
java·程序人生·职场发展·娱乐
sonnet-10296 分钟前
函数式接口和方法引用
java·开发语言·笔记
Bat U10 分钟前
JavaEE|多线程(二)
java·开发语言
_Evan_Yao18 分钟前
RAG中的“Chunk”艺术:我试过10种切分策略后总结的结论
java·人工智能·后端·python·软件工程
魂梦翩跹如雨1 小时前
数据库的“契约” —— 约束(Constrains)
java·数据库·mysql
独自破碎E1 小时前
面试官:你有用过Java的流式吗?比如说一个列表.stream这种,然后以流式去处理数据。
java·开发语言
2601_949818092 小时前
头歌答案--爬虫实战
java·前端·爬虫
2601_949817922 小时前
大厂Java进阶面试解析笔记文档
java·笔记·面试
郭wes代码2 小时前
大三Java课设:一行行敲出来的贪吃蛇,老师以为我是CV的
java·开发语言
HYNuyoah2 小时前
docker 安装win10系统
运维·docker·容器