Kubernetes中Pod使用方法
admin
2023-03-25 21:01:26
0

Pod是Kubernetes调度的最小单元。一个Pod可以包含一个或多个容器,因此它可以被看作是内部容器的逻辑宿主机。

资源限制

pod和container的资源请求和限制

#cpu上限
spec.containers[].resources.limits.cpu

#内存上限
spec.containers[].resources.limits.memory

#创建时分配的基本cpu资源
spec.containers[].resources.requests.cpu

#创建时分配的基本内存资源
spec.containers[].resources.requests.memory

示例演示(在master1端操作)

  • 创建pod2.yaml文件
vim pod2.yaml

apiVersion: v1
kind: Pod
metadata:
  name: frontend        
  #Pod资源的名称
spec:
  containers:
  - name: db        
  #容器1的名称
    image: mysql
    env:
    - name: MYSQL_ROOT_PASSWORD
      value: "password"
    resources:
      requests:
        memory: "64Mi"
        cpu: "250m"
      limits:
        memory: "128Mi"
        cpu: "500m"
  - name: wp        
  #容器2的名称
    image: wordpress
    resources:
      requests:
        memory: "64Mi"
        cpu: "250m"
      limits:
        memory: "128Mi"
        cpu: "500m"
  • 创建资源
kubectl apply -f pod2.yaml
  • 查看资源详细信息
kubectl describe pod frontend
  • 查看对应节点上Pod资源的占用情况
kubectl describe nodes 192.168.142.130
  • 查看命名空间
kubectl get ns

重启策略

1:Always:当容器终止推出后,总是重启容器,默认策略

2:Onfailure:当容器异常退出(退出码为非0)时,重启容器

3:Never:当容器终止退出,从不重启资源

注意:k8s中不支持重启pod资源,只有删除重建

示例演示

  • 默认的重启策略是Always
kubectl edit deploy
#输入/restartPolicy查找
restartPolicy: Always       
#没有设定重启策略时默认为Always

#创建pod3.yaml文件
vim pod3.yaml

apiVersion: v1
kind: Pod
metadata:
  name: foo
spec:
  containers:
  - name: busybox
    image: busybox
    args:       
    #参数
    - /bin/sh   
    #在shell环境中
    - -c        
    #command命令
    - sleep 30; exit 3      
    #容器启动后休眠30s,异常退出返回状态码为非0值

#创建资源
kubectl apply -f pod3.yaml

kubectl get pods
#此时会出现Error报错,因刚刚设置的异常退出,一会再查看时RESTARTS重启值会变为1、
  • 添加重启策略Never
#修改pod3.yaml文件
vim pod3.yaml

apiVersion: v1
kind: Pod
metadata:
  name: foo
spec:
  containers:
  - name: busybox
    image: busybox
    args:
    - /bin/sh
    - -c
    - sleep 10              
    #修改休眠时间为10s
  restartPolicy: Never      
    #添加重启策略

#创建资源
kubectl apply -f pod3.yaml

健康检查,又称为探针(Probe)

  • 注意:规则可以同时定义
livenessProbe 如果检查失败,将杀死容器,根据Pod的restartPolicy来操作

ReadinessProbe 如果检查失败,kubernetes会把Pod从service endpoints后端节点中中剔除
  • Probe支持三种检查方法
httpGet 发送http请求,返回200-400范围状态码为成功

exec 执行Shell命令返回状态码是0为成功

tcpSocket 发起TCP Socket建立成功

示例演示

  • 创建资源
#创建pod4.yaml文件
vim pod4.yaml

apiVersion: v1
kind: Pod
metadata:
  labels:
    test: liveness
  name: liveness-exec
spec:
  containers:
  - name: liveness
    image: busybox
    args:
    - /bin/sh
    - -c
    - touch /tmp/healthy; sleep 30; rm -rf /tmp/healthy
    #创建一个空文件,休眠30s,删除这个空文件
    livenessProbe:
      exec:
      #探测健康
        command:
        #command命令
        - cat
        #执行查看命令
        - /tmp/healthy  
        #创建的空文件
      initialDelaySeconds: 5
      #容器创建完成5秒之后开始健康检查
      periodSeconds: 5  
      #检查的间隔频率为5秒
  • 刷新资源
#创建资源
kubectl apply -f pod4.yaml

kubectl get pods
#当中状态不断改变,就代表它正在不断的进行检查,然后不断的执行重启策略,其中的RESTARTS重启值也会随之增加

谢谢阅读!

相关内容

热门资讯

美媒证实一艘美国商船遭伊朗无人... 新华社华盛顿5月10日电 (记者徐剑梅 黄强)据美国福克斯新闻数字网报道,一艘美国商船10日在波斯湾...
特朗普声称伊朗47年来一直在“... 美国总统特朗普于当地时间5月10日在社交媒体发文,“猛烈抨击”伊朗长期“玩弄”美国和世界,同时还痛批...
学生放学回家后又返回学校坠亡,... 学生符某放学后回到家中,后又从家中返回学校,并于当晚从学校教学楼楼顶坠亡。符某父母随后将学校告上法庭...
泽连斯基称乌已向俄方提交100... 当地时间10日,乌克兰总统泽连斯基表示,乌俄双方将以“千人换千人”的方式交换战俘,乌方已向俄方提交了...
国网上海市电力公司举办“明灯引... 5月7日至9日,在第十个“中国品牌日”来临之际,国网上海市电力公司(以下简称“国网上海电力”)以“明...
字跳申请会话信息的发送方法专利... 国家知识产权局信息显示,北京字跳网络技术有限公司申请一项名为“会话信息的发送方法、装置、电子设备、存...
非开挖定向钻机厂家选择指南:郑... 导语:非开挖定向钻机作为市政管道铺设、能源管线穿越等场景的核心设备,其性能稳定性与厂家服务能力直接影...
你昂贵的DDR5内存可能是假货... 快科技5月10日消息,内存价格近期持续走高,亚洲市场出现大量假冒DDR5内存模块,且外观极具迷惑性。...
6G,迎利好!工信部批复 工信部批复6G技术试验频率。 为进一步推动我国6G技术研发、标准研制与产业化进程,工业和信息化部近日...
涉疫邮轮5名法国公民回国,一人... △“洪迪厄斯”号邮轮(资料图)法国总理勒科尔尼10日在社交媒体说,涉汉坦病毒疫情邮轮“洪迪厄斯”号上...