2018-02-23 kubenetes Services

https://www.kubernetes.org.cn/replication-controller-kubernetes

官方定义:

A Kubernetes Service is an abstraction which defines a logical set of Pods and a policy by which to access them - sometimes called a micro-service

参考:http://blog.csdn.net/liyingke112/article/details/76022267

我的理解:

Service提供了基于pod的抽象,是一个大型集群系统中出现错误的自发现和动态调整的关键组件。

创建一个service将会为其分配一个新的独立与任何pod或者节点的IP,可以通过固定的方式访问服务,而不必关系服务是在那里运行的

Kubernetes proxy会自动处理调用service的请求,proxy 还会在这些pod 之间进行负载平衡

调用方可以通过两种方式获得service 的IP 地址:环境变量或者DNS(推荐使用) DNS的话要考虑命名空间,默认的是default,在同一个命名空间中,可以直接使用服务名来找到该服务。

创建一个service,也是编写一个yaml文件,然后使用 create来创建 使用第二种方式(具体见上一篇文章)

这个是一个service的实例:

2018-02-23 kubenetes Services_第1张图片

另一个实例

2018-02-23 kubenetes Services_第2张图片

上面的选择器会匹配到所有具有 tier: wp-mysql标签的pod

这个service会创建一个新的“集群IP”,集群中的其他pod都可以访问到该IP地址(但是外部节点都没法访问),任何对该机器IP的访问都会被负载平衡代理到一个底层服务节点(selector所匹配到的pod)

如果正在运行DNS,service的集群IP还会被分配一个逻辑名称,其他客户端可以使用这个逻辑名称,在wordpress pod 的配置中就可以使用该逻辑名称,好处是不管IP是什么,这个pod都可以根据这个逻辑名称找到数据库。

Service的Type:

NodePort:除了使用ClusterIP外,也将service 的port映射到每个指定的内部port上,

ClusterIP:使用集群内的私有IP -- 默认值

LoadBalancer:  使用一个ClusterIP & NodePort 但是会向 could provider申请映射到service本身的负载均衡

LoadBalancer 只有云平台才支持

之后在定义wordpress的pod的时候就可以直接使用mysql的这个service,让WordPress通过这个service来访问mysql数据库:具体做法就是将WORDPRESS_DB_HOST 配置为 mysql(service的名字)

你可能感兴趣的:(2018-02-23 kubenetes Services)