k8s - service 微服务

本文介绍了Kubernetes Service的类型,包括ClusterIP、NodePort、LoadBalancer和ExternalName模式,强调了IPVS代理模式的优势,并展示了如何在实践中配置和使用这些服务。
摘要由CSDN通过智能技术生成

目录

简介

service的类型:

IPVS 代理模式

实践

ClusterIP

Kubernetes 提供了一个 DNS 插件 Service

Headless无头模式 

NodePort方式 

 LoadBalancer模式

ExternalName方式


简介

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

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

service的类型:

ClusterIP:默认值,k8s系统给service自动分配的虚拟IP,只能在集群内部访问。

NodePort:将Service通过指定的Node上的端口暴露给外部,访问任意一个NodeIP:nodePort都将路由到ClusterIP。

LoadBalancer:在 NodePort 的基础上,借助 cloud provider 创建一个外部的负载均衡器,并将请求转发到 <NodeIP>:NodePort,此模式只能在云服务器上使用。 ExternalName:将服务通过 DNS CNAME 记录方式转发到指定的域名(通过 spec.externlName 设定)。   

IPVS 代理模式

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

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

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

所有节点安装IPVS

yum install ipvsadm -y

修改成lvs 模式 master

kubectl edit cm kube-proxy -n kube-system

 刷新kube-proxy,模式改变

kubectl get pod -n kube-system |grep kube-proxy | awk '{system("kubectl delete pod "$1" -n kube-system")}'

 rr轮询可见

 修改Mode是添加了模块

lsmod | grep ip_vs

 查看ip

IPVS模式下,kube-proxy会在service创建后,在宿主机上添加一个虚拟网卡:kube-ipvs0,并分配service IP。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值