Kubernetes基本概念和术语,以及Kubectl命令大全

Kubernetes基本概念和术语

kubernetes是一个高度自动化的资源控制系统,它通过跟踪对比etcd库保存的“资源期望状态”与当前环境的“实际资源状态”的差异来实现自动化控制和自动纠错的高级功能

Master

是集群的控制节点,所有的控制指令都发给他

Master上运行着以下进程:

  1. Kubernetes API Server:提供rest接口,增删改查资源
  2. Kubernetes controller manager:所有资源的自动化控制中心
  3. Kubernetes Scheduler: 负责资源调度(Pod调度)
  4. etcd服务,所有资源对象的数据全部保存在etcd中

Node

即docker容器节点,运行具体的任务,当Node宕机时,Master会自动化任务分配到其他Node执行

Node包括以下进程:

  1. kubelet:负责Pod对应容器的启停工作,同时和master联系,实现集群管理
  2. kube-proxy:实现kubernetes service通讯和负载均衡的重要组件
  3. Docker Engine:docker容器,负责容器的创建和管理工作

Pod

容器的载体,Pod里面有个叫pause容器的根容器,Pod里的多个业务容器共享pause容器的ip,共享pause容器挂载的Volumn,当pod中某个容器停止时,kubernetes会重启这个pod(重启pod中所有容器);当pod所在Node挂掉时,会将pod重新调度到其他节点上。

pod管理的对象有:RC、Deployment、ReplicasSet、DaemonSet、StatefulSet、Job

# Pod的可以对cpu和memory进行分配
spec: 
  containers:
  - name: d b 
    image: mysql resources :
    requests:
      memory : "64Mi" # Mi单位字节数
      cpu : "250m" # 1000m为一个cpu
    limits:
      memory: "128Mi" 
      cpu: "500m"

Label(标签)

label是一个键值对,可以任意数量附加到Node、Pod、Service、RC等上,同一个label也可以附加到不同的资源上。标签一般用来对资源进行分组,方便管理。常见的标签有:

版本标签:
环境标签:
架构标签:
分区标签:
质量管控标签:

label和label selector搭配使用

selector: 
  matchLabels :
    app: myweb
  matchExpressions:
    - {key: tier, operator: In, values: [frontend]}
    - {key: environment , operator : NotIn , values: [dev]}

Label Selector在Kubernetes中的重要使用场景有以下几处:

  1. kube-controller通过label selector监控副本数量,实现高可用的自动化流程
  2. kube-proxy通过service的label selector来选择对应的pod,自动建立service到pod的请求路由表,实现智能负载均衡
  3. 定义一些特定的label,kube-scheduler进程实现Pod的定向调度

Replication Controller(RC)

它其实定义的是一中期望场景:

  1. Pod期待的副本数
  2. 用于筛选目标Pod的label selector
  3. 当Pod小于目标数时,用Pod模板创建新的Pod
apiVersion: v1
kind: ReplicationController
metadata:
  name: mysql
spec:
  replicas: 1
  selector:
    app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      - name: mysql
        image: mysql:5.7
        ports: 
        - containerPort: 3306
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: "123456"

Replicas Set(RS)

是对Replication Controller的一个升级

Deployment

是对Replicas Set的一个重新定义

apiVersion: apps/v1
kind: Deployment
metadata: 
  name: frontend
spec:
  replicas: 1
  selector:
    matchLabels: 
      tier: frontend
    matchExpressions:
      - {key: tier, operator: In, values: [frontend]}
  template:
    metadata:
      labels:
        app: app-demo
        tier: frontend
    spec:
      containers:
      - name: tomcat-demo
        image: tomcat
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 8080

Kubectl命令行

基本形式:

kubectl [command] [type] [name] [flags]
  • [type]区分大小写,可以单数、复数、简写
  • [name]区分大小写,如果不写,就展示全部对象列表

type


command


flags

-o 指定输出格式

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值