一、service资源的由来
k8s控制器管理的pod对象终止后会由新建的资源对象所取代,扩容缩容后也会带来pod对象群体的变化,新建后的pod的IP地址访问接口也会变化,等等…假设扩容pod资源,pod会根据pod资源创建自动生成,从而影响达成规模扩展的目的。为此,出现了Service资源来解决这些问题
1、什么是service资源
service资源基于标签选择器将一组pod定义成一个逻辑组合,通过自己的IP地址和端口,调度代理至组内的pod对象之上,间接实现了组内pod资源的负载均衡(匹配到的后端pod资源多个时)实现了请求流量的分发机制,service对象的IP地址也称为cluster IP,它是一种虚拟IP地址,service对象创建后即保持不变,并能够被同一集群中的pod资源所访问,service端口用于接收客户端请求并将其转发至其后端的pod相应端口之上,这种代理机制也被称为端口代理(四层代理),工作于TCP/IP协议的传输层,service与pod对象关联关系通过标签选择器以松耦合的方式建立,可以先于pod对象创建
2、service 资源如何工作
1、service通过api server持续监视着(watch)标签选择器匹配到的后端pod对象,并实时跟踪各对象的变动,service并不直接链接至pod对象,而是通过一个中间层(endpoint)资源对象,endpoint是由IP和端口组成的列表,而IP和端口则来自service的标签选择器匹配到的pod资源,而service关