8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

为什么 kubectl run onfail1 --image=alpine --restart=OnFailure -- exit 0 pod status=CrashLoopBackOff 我认为应该完成

isctest012 2月前

28 0

在这里输入图像描述kubectl run onfail1 --image=alpine --restart=OnFailure -- exit 0.最后,这个 pod status=CrashLoopBackOff.我认为应该完成,因为退出代码 = 0,所以这个...

在此处输入图片描述

kubectl run onfail1 --image=alpine --restart=OnFailure --exit 0。

最后这个pod status=CrashLoopBackOff。

我认为应该完成,因为退出代码=0,所以这个pod不需要重新启动。

为什么?这个状态应该已完成。你能告诉我为什么吗?

帖子版权声明 1、本帖标题:为什么 kubectl run onfail1 --image=alpine --restart=OnFailure -- exit 0 pod status=CrashLoopBackOff 我认为应该完成
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由isctest012在本站《kubernetes》版块原创发布, 转载请注明出处!
最新回复 (0)
  • doa 2月前 0 只看Ta
    引用 2

    要使 Pod 进入“已完成”状态,成功完成后不应重新启动它。以下是实现此目的的方法:

    解决方案 1:使用 kubectl create job使用 Kubernetes Job,它旨在运行任务直至完成:

    kubectl create job onfail1 --image=alpine -- /bin/sh -c "exit 0"
    

    解决方案 2:使用 kubectl run 并加上 --restart=Never

    kubectl run onfail1 --image=alpine --restart=Never -- /bin/sh -c "exit 0"
    

    --restart=OnFailure:如果 pod 以非零退出代码退出,则会重新启动 pod,这可能会导致意外重启,如果容器退出得太快,则会导致 CrashLoopBackOff。--restart=Never:这可防止 pod 重新启动,使其成功完成并显示已完成状态。

  • 您可以使用以下命令查看错误:

    kubectl describe pods onfail1
    

    导致该错误的原因是在 $PATH 中未找到命令“exit”。

    您可以按如下方式编辑命令,pod 将成功完成

    kubectl run onfail1 --image=alpine --restart=OnFailure -- echo "Hello world"
    
返回
作者最近主题: