看图
四种类型
ClusterIP
NodePort
LoadBalancer
ExternalName
路由
ClusterIP
clusterIP主要在每个node节点使用iptables,将发向clusterIP对应端口的数据,转发到kube-proxy中。然后kube-proxy自己内部实现有负载均衡的方法,并可以查询到这个service下对应pod的地址和端口,进而把数据转发给对应的pod的地址和端口。NodePort
nodePort的原理在于在node上开了一个端口,将向该端口的流量导入到kube-proxy,然后由kube-proxy进一步导给对应的pod。LoadBalancer
LoadBalancer跟nodePort其实是同一种方式。参见这里的说明。区别在于LoadBalancer比nodePort多了一步,就是可以调用cloud provider去创建LB来向节点导流。