我对Kubernetes Service的认识

2018-02-23  本文已影响42人  贾磊_cd

官方定义:

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

我的理解:

Service提供了基于pod的抽象,是一个大型集群系统中出现错误的自发现和动态调整的关键组件。
创建一个service将会为其分配一个新的独立与任何pod或者节点的IP,可以通过固定的方式访问服务,而不必关系服务是在那里运行的
Kubernetes proxy会自动处理调用service的请求,proxy 还会在这些pod 之间进行负载平衡
调用方可以通过两种方式获得service 的IP 地址:环境变量或者DNS(推荐使用) DNS的话要考虑命名空间,默认的是default,在同一个命名空间中,可以直接使用服务名来找到该服务。
创建一个service,也是编写一个yaml文件,然后使用 create来创建 使用第二种方式(具体见上一篇文章)

这个是一个service的实例:

apiVersion: v1
kind: Service
metadata:
  labels:
    name: wordpress
  name: wordpress
spec:
  type: NodePort
  ports:
  - port: 80
    nodePort: 30000
  selector:
    name: wp

另一个实例

kind: Service
apiVersion: v1
metadata:
  name: mysql
spec:
  selector:
    tier: wp-mysql
    ports:
    - port: 3306

上面的选择器会匹配到所有具有 tier: wp-mysql标签的pod
这个service会创建一个新的“集群IP”,集群中的其他pod都可以访问到该IP地址(但是外部节点都没法访问),任何对该机器IP的访问都会被负载平衡代理到一个底层服务节点(selector所匹配到的pod)
如果正在运行DNS,service的集群IP还会被分配一个逻辑名称,其他客户端可以使用这个逻辑名称,在wordpress pod 的配置中就可以使用该逻辑名称,好处是不管IP是什么,这个pod都可以根据这个逻辑名称找到数据库。

Service的Type:

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

上一篇下一篇

猜你喜欢

热点阅读