zoukankan      html  css  js  c++  java
  • 【08】Kubernets:Service

    写在前面的话

    在 K8S 第一节的时候我们简单提到过 Service 的工作模式有三种:userspace / iptables / ipvs。并且已经知道在目前新版本中默认是 ipvs,前提是在按照 K8S 的时候配置了 ipvs 模块。

    Service 资源清单

    前面就已经知道 service 简称 svc,所以我们可以直接通过 explain 查看资源清单的参数如下表:

    svc
    apiVersion     v1 
    kind     Service
    metadata     和其他一样,name / labels / namespace 等
    spec      
      clusterIP   定义 Service 的 IP,一般在 type 是 ClusterIP 的时候才配置,大多时候随机分配
      ports    
        name 名称
        nodePort 在 type 是 NodePort 的时候使用,就是大于 30000 的本机映射端口
        port Service 的端口
        targetPort Pod 的端口
      selector   标签选择器,直接键值对
      sessionAffinity   配置分配规则,支持 ClientIP / None
      type   ExternalName, ClusterIP, NodePort, LoadBalancer(一般用于云)

    简单的资源清单示例:

    apiVersion: v1
    kind: Service
    metadata:
      name: redis-svc
      namespace: default
    spec:
      type: ClusterIP
      selector:
        app: redis
        role: logstore
      ports:
      - name: redis-port
        port: 6373
        targetPort: 6379

    运行查看:

    kubectl apply -f svc-demo.yaml
    kubectl get svc

    结果如图:

    资源记录解析名字格式:SVC_NAME.NS_NAME.DOMAIN.LTD.

    例如上面的 redis  名字为:redis.default.svc.cluster.local.

    当我们 type 使用 NodePort 的时候,就可以在 ports 里面配置 nodePort 参数(大于 30000 端口,不指定随机)。

    一定要确保该端口没用被其他服务占用。

    当我们这只 CluterIP 为 None 的时候,资源记录直接解析到 Pod。此时再使用 dig 添加本地解析时,该资源记录需要解析到 kube-dns 的 IP 地址。

  • 相关阅读:
    MongoDB 连接
    MongoDB 概念解析
    Linux平台安装MongoDB
    window平台安装MongoDB
    MongoDB 简介
    NoSQL 简介
    Docker有用的资源
    Docker常见仓库Redis
    Docker常见仓库MongoDB
    微信小程序
  • 原文地址:https://www.cnblogs.com/Dy1an/p/11011947.html
Copyright © 2011-2022 走看看