pod:Kubernetes(k8s)创建pod的两种方式

一、前言

docker可以创建容器,kubernetes不能直接创建容器,kubernetes创建的是pod,pod里面包含了一个或者多个容器。

二、pod

Pod是可以在kubernetes中创建和管理的,最小可部署的计算单元。

Pod(就像在鲸鱼荚或者豌豆荚中)是一组(一个或多个)容器;这些容器共享存储、网络、以及怎样运行这些容器的声明。Pod中的内容总是并置(colocated)的并且一同调度,在共享的上下文中运行。Pod所建模的是特定于应用的“逻辑主机”,其中包含一个或多个应用容器,这些容器相对紧密地耦合在一起。在非云环境中,在相同的物理机或虚拟机上运行的应用类型于在同一逻辑主机上运行的云应用。

除了应用容器,Pod还可以在Pod启动期间运行init容器。你也可以在集群中支持临时性容器的情况下,为调试的目的注入临时性容器。

pod里面有一个或者多个容器,常见的容器有docker容器,containerd容器,除了Docker之外,kubernetes支持很多其他容器运行时,Docker 是最有名的容器运行时,使用Docker的术语来描述Pod会很有帮助。

Pod的共享上下文包括一组Linux命令空间,控制组(cgroup)和可能一些其他的隔离方面,即用来隔离Docker容器的技术。在Pod的上下文中,每个独立的应用可能会进一步实施隔离。

就Docker概念的术语而言,Pod类似于共享命令空间和文件系统卷的一组Docker容器。

三、创建Pod
kubernetes创建pod一般有两种方式:

  1. 使用命令行的方式创建
  2. 使用yaml文件创建

a. 使用命令行的方式创建pod
创建pod的命令为kubectl run,kubectl 创建pod的帮助可以查看官方网页版:
https://kubernetes.io/docs/reference/generated/kubectl/kubectl-commands#create

查看kubectl run 创建pod的帮助

kubectl run --help

创建一个pod

kubectl run nginx --image=nginx

查看pod

kubectl get pod		# pod状态为runing表示运行成功

删除pod

kubectl delete pod nginx  # 使用 --force强制删除

创建pod,指定镜像下载策略
使用nginx镜像创建一个pod,镜像的下载策略为ifNotPresent本地没有才下载镜像
镜像的下载策略:Always:每次都下载最新的镜像;Never:只使用本地的镜像,从不下载,ifNotPresent:本地没有才下载镜像 默认值为:Always

kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent
  • –image=nginx 表示使用nginx镜像

  • –image-pull-policy=IfNotPresent表示镜像下载策略为IfNotPresent本地没有才下载镜像

      kubectl  get pod
      kubect delete pod nginx --force
    

创建pod指定环境变量和标签
查看pod标签的帮助

# kubectl run --help|grep labels
# kubectl run --help|grep labels
  # Start a hazelcast pod and set labels "app=hazelcast" and "env=prod" in the container.
  kubectl run hazelcast --image=hazelcast/hazelcast --labels="app=hazelcast,env=prod"
  -l, --labels='': Comma separated labels to apply to the pod(s). Will override previous values

创建pod指定环境变量和标签

kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --env "xx=1" --env "yy=2" --labels="xx=1,yy=2"

查看pod部署在哪个节点上

kubectl get pod -o wide
  • --env xx=1 设置环境变量
  • --labels xx=1 打标签

进入到pod里,查看变量

kubectl exec -it nginx -- bash
# kubectl exec -it nginx -- bash
# echo $xx $yy

查看pod的标签,–show-labels参数显示标签

kubectl get pod -o wide --show-labels			# 查看所有pod的标签
kubectl get pod nginx -o wide --show-labels			# 查看指定pod的标签
# kubectl get pod -o wide --show-labels 
NAME                      READY   STATUS    RESTARTS   AGE     IP               NODE           NOMINATED NODE   READINESS GATES   LABELS
nginx                     1/1     Running   0          7m26s   192.168.69.218   k8s-worker02   <none>           <none>            xx=1,yy=2

b. 使用yaml文件的方式创建pod
yaml文件概述
YAML是“YAML Ain’t a Markup Language”(YAML不是一种标记语言)的递归缩写。YAML的意思是:“Yet Another Markup Language”(仍是一种标记语言)。主要强调这种语言是以数据为中心,而不是以标记语言为重心,例如像xml语言就会使用大量的标记。

YAML是一个可读性高,易于理解,用来表达数据序列化的格式。它的语法和其他高级语言类似,并且可以简单表达清单(数组)、散列表,变量等数据形态。它使用空白符号缩进和大量依赖外观的特色,特别适合用来表达或者编辑数据结构、这种配置文件等。YAML的配置文件后缀为 .yaml

  • yaml文件基本语法
  • YAML使用可打印的Unicode字符,可使用UTF-8或UTF-16
  • 数据结构采用键值对的形式,即键名称:值,注意冒号后面要有空格。
  • 每个清单(数组)成员以单行表示,并用端杠(-)+空白 起始。或使用方括号([]),并用逗号(,)+空白分开成员。
  • 每个散列表的成员用冒号(:)+ 空白分开键值和内容。或者用大括号({}),并用逗号(,)+ 空白分开。
  • 字符串值一般不使用引号,必要时可以使用,使用双引号表示字符串时,会转义字符串中的特殊字符(例如\n)。使用单引号时不会转义字符串中的特殊字符。
  • 大小写敏感
  • 使用缩进表示层级关系,缩进允许使用tab,只允许空格,因为有可能在不同系统下tab长度不一样
  • 缩进的空格数可以任意,只要相同层级的元素左对齐即可
  • 在单一文件中,可以连续三个连字号(—)区分多个文件。还有选择新的连续三个点号(…)用来表示文件结尾。
  • ‘#’ 表示注释,可以出现在一行中的任何位置,单行注释
  • 在使用逗号及冒号时,后面都必须接一个空白字符,所以可以在字符串或数值中自由加入分隔符号(例如:5,280或http://www.wikipedia.org)而不需要使用引号。

接下来使用yaml文件的方式创建pod

–dry-run 模拟运行,并不会真的创建一个pod,–dry-run=client输出信息少,–dry-run=server输出信息多,-o yaml以文件格式输出

kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --dry-run=server -o yaml
# kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --dry-run=server -o yaml
apiVersion: v1
kind: Pod
metadata:
  creationTimestamp: "2024-02-22T09:41:10Z"
  labels:
    run: nginx
  managedFields:
  - apiVersion: v1
    fieldsType: FieldsV1
    fieldsV1:
      f:metadata:
        f:labels:
          .: {}
          f:run: {}
      f:spec:
        f:containers:
          k:{"name":"nginx"}:
            .: {}
            f:image: {}
            f:imagePullPolicy: {}
            f:name: {}
            f:resources: {}
            f:terminationMessagePath: {}
            f:terminationMessagePolicy: {}
        f:dnsPolicy: {}
        f:enableServiceLinks: {}
        f:restartPolicy: {}
        f:schedulerName: {}
        f:securityContext: {}
        f:terminationGracePeriodSeconds: {}
    manager: kubectl-run
    operation: Update
    time: "2024-02-22T09:41:10Z"
  name: nginx
  namespace: default
  selfLink: /api/v1/namespaces/default/pods/nginx
  uid: 2c8f32de-5201-4cb2-8a93-13382f28eda1
spec:
  containers:
  - image: nginx
    imagePullPolicy: IfNotPresent
    name: nginx
    resources: {}
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: default-token-2jswl
      readOnly: true
  dnsPolicy: ClusterFirst
  enableServiceLinks: true
  preemptionPolicy: PreemptLowerPriority
  priority: 0
  restartPolicy: Always
  schedulerName: default-scheduler
  securityContext: {}
  serviceAccount: default
  serviceAccountName: default
  terminationGracePeriodSeconds: 30
  tolerations:
  - effect: NoExecute
    key: node.kubernetes.io/not-ready
    operator: Exists
    tolerationSeconds: 300
  - effect: NoExecute
    key: node.kubernetes.io/unreachable
    operator: Exists
    tolerationSeconds: 300
  volumes:
  - name: default-token-2jswl
    secret:
      defaultMode: 420
      secretName: default-token-2jswl
status:
  phase: Pending
  qosClass: BestEffort

–dry-run=client输出信息如下:输出内容恰到好处

kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --dry-run=client -o yaml
# kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --dry-run=client -o yaml
apiVersion: v1
kind: Pod
metadata:
  creationTimestamp: null
  labels:
    run: nginx
  name: nginx
spec:
  containers:
  - image: nginx
    imagePullPolicy: IfNotPresent
    name: nginx
    resources: {}
  dnsPolicy: ClusterFirst
  restartPolicy: Always
status: {}

生成创建pod的yaml文件

kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --dry-run=client -o yaml > nginx.yaml

使用nginx.yaml 文件创建pod

kubectl create -f nginx.yaml

删除pod

kubectl delete -f nginx.yaml

yaml文件里有很多变量,可以使用kubectl explain查看yaml文件每个字段的含义

kubectl explain pods
# kubectl explain pods
KIND:     Pod
VERSION:  v1

DESCRIPTION:
     Pod is a collection of containers that can run on a host. This resource is
     created by clients and scheduled onto hosts.

FIELDS:
   apiVersion	<string>
     APIVersion defines the versioned schema of this representation of an
     object. Servers should convert recognized schemas to the latest internal
     value, and may reject unrecognized values. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources

   kind	<string>
     Kind is a string value representing the REST resource this object
     represents. Servers may infer this from the endpoint the client submits
     requests to. Cannot be updated. In CamelCase. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds

   metadata	<Object>
     Standard object's metadata. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata

   spec	<Object>
     Specification of the desired behavior of the pod. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status

   status	<Object>
     Most recently observed status of the pod. This data may not be up to date.
     Populated by the system. Read-only. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status

查看一级字段下包含了哪些字段,对某个字段不了解,先使用kubectl explain查看

kubectl explain pod.spec
kubectl explain pods.spec.containers
kubectl explain pods.spec.containers.ports

容器containers里也可以自定义变量,定义变量的时候:变量的值如果是数字,需要加“”

cat nginx.yaml
# cat nginx.yaml 
apiVersion: v1				# api 版本
kind: Pod					# 指定资源类型
metadata:					# 元数据
  creationTimestamp: null	
  labels:					# 下面是对标签的定义
    run: nginx				
  name: nginx				# pod 名称指定
spec:						# 规格
  containers:				# 下面是对容器的定义
  - image: nginx			# 拉取的镜像
    imagePullPolicy: IfNotPresent		# 指定镜像拉取策略
    name: nginx						# 容器名
    resources: {}			#  指定容器资源(CPU,内存等)
  dnsPolicy: ClusterFirst		# 指定DNS策略
  restartPolicy: Always			# 容器重启策略
  status: {}

yaml文件里面的字典和列表
先,生成一个yaml文件

kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --dry-run=client -o yaml
# kubectl run nginx --image=nginx --image-pull-policy=IfNotPresent --dry-run=client -o yaml
apiVersion: v1
kind: Pod
metadata:
 creationTimestamp: null
 labels:
 run: nginx
 name: nginx
spec:
 containers:
 - image: nginx
 imagePullPolicy: IfNotPresent
 name: nginx
 resources: {}
 dnsPolicy: ClusterFirst
 restartPolicy: Always
status: {}

我们注意到,有的字段前面有 -,有的没有 - 的是字典,字典里面不能有重复变量,有 - 的是列表,列表里面的每一个对象都是一个匿名字典,在列表中,对象的第一个字段要加 -

例如: 当pod里面有多个容器时候,containers可以定义多个,每个容器是一个对象,每个容器的第一个变量就加 -

apiVersion: v1
kind: Pod
metadata:
 creationTimestamp: null
 labels:
 run: nginx
 name: nginx
spec:
 containers:
 - image: nginx
 imagePullPolicy: IfNotPresent
 name: nginx
 resources: {}
 - image: nginx
 imagePullPolicy: IfNotPresent
 name: nginx
 resources: {}
 - image: nginx
 imagePullPolicy: IfNotPresent
 name: nginx
 resources: {}
 dnsPolicy: ClusterFirst
 restartPolicy: Always

status: {}

查看不同类型apiVersion
不同的kubernetes资源类型,apiVersion是不一样的,Pod的apiVersion为v1
kubectl api-versions 查看所有的apiVersion

# kubectl api-versions
admissionregistration.k8s.io/v1
admissionregistration.k8s.io/v1beta1
apiextensions.k8s.io/v1
apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1
apiregistration.k8s.io/v1beta1
apps/v1
authentication.k8s.io/v1
authentication.k8s.io/v1beta1
authorization.k8s.io/v1
authorization.k8s.io/v1beta1
autoscaling/v1
autoscaling/v2beta1
autoscaling/v2beta2
batch/v1
batch/v1beta1
certificates.k8s.io/v1
certificates.k8s.io/v1beta1
coordination.k8s.io/v1
coordination.k8s.io/v1beta1
crd.projectcalico.org/v1
discovery.k8s.io/v1beta1
events.k8s.io/v1
events.k8s.io/v1beta1
extensions/v1beta1
networking.k8s.io/v1
networking.k8s.io/v1beta1
node.k8s.io/v1beta1
policy/v1beta1
rbac.authorization.k8s.io/v1
rbac.authorization.k8s.io/v1beta1
scheduling.k8s.io/v1
scheduling.k8s.io/v1beta1
storage.k8s.io/v1
storage.k8s.io/v1beta1
v1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值