0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

最常见的退出码介绍

马哥Linux运维 来源:马哥Linux运维 作者:马哥Linux运维 2022-08-02 09:57 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

为什么我的容器没有运行?

回答这个问题需要知道 Docker 容器为什么退出,退出码会提示容器停止运行的情况。本文列出了最常见的退出码,来回答两个重要问题:

这些退出码是什么意思?

导致该退出码的动作是什么?

exit code:代表一个进程的返回码,通过系统调用 exit_group 来触发。在 POSIX 中,0 代表正常的返回码,而 1-255 代表异常返回码,不过一般错误码都是 1。这里有一张附表 Appendix E. Exit Codes With Special Meanings

如何查看退出码

方法一:查看 pod 中的容器退出码

$kubectldescribepodxxx

74a515f8-11a5-11ed-ba43-dac502259ad0.jpg

方法二:用 Docker 查看

$ dockerps--filter"status=exited"
$ dockerinspect--format='{{.State.ExitCode}}'

方法三:手动输出

$ dockercontainerrunalpinesh-c"exit1"

$dockercontainerls-a

CONTAINERIDIMAGECOMMANDCREATEDSTATUS
61c688005b3aalpine"sh-c'exit1'"AboutaminuteagoExited(1)3secondsago

常见退出码

Exit Code 0

退出代码0表示特定容器没有附加前台进程。

该退出代码是所有其他后续退出代码的例外。

这不一定意味着发生了不好的事情。如果开发人员想要在容器完成其工作后自动停止其容器,则使用此退出代码。

如果你执行 docker run hello-world, 你会得到“Hello from docker!”,但查看容器的时候docker ps -a | grep hello-world,会发现状态码为 0

74b736d4-11a5-11ed-ba43-dac502259ad0.jpg

Exit Code 1

程序错误,或者 Dockerfile 中引用不存在的文件,如 entrypoint 中引用了错误的包

程序错误可以很简单,例如 “除以0”,也可以很复杂,比如空引用或者其他程序 crash

Exit Code 137

表明容器收到了 SIGKILL 信号,进程被杀掉,对应 kill -9

引发 SIGKILL 的是 Docker Kill。这可以由用户或由 Docker 守护程序来发起,手动执行:docker kill

137 比较常见,如果 pod 中的 limit 资源设置较小,会运行内存不足导致 OOMKilled,此时 state 中的 "OOMKilled" 值为 true,你可以在系统的 dmesg 中看到 oom 日志

Exit Code 139

表明容器收到了 SIGSEGV 信号,无效的内存引用,对应 kill -11

一般是代码有问题,或者 docker 的基础镜像有问题

Exit Code 143

表明容器收到了 SIGTERM 信号,终端关闭,对应 kill -15

一般对应 docker stop 命令

有时 docker stop 也会导致 Exit Code 137。发生在与代码无法处理 SIGTERM 的情况下,docker 进程等待十秒钟然后发出 SIGKILL 强制退出。

不常用的一些 Exit Code

Exit Code 126: 权限问题或命令不可执行

Exit Code 127: Shell 脚本中可能出现错字且字符无法识别的情况

Exit Code 1 或 255:因为很多程序员写异常退出时习惯用 exit(1) 或 exit(-1),-1 会根据转换规则转成 255。这个一般是自定义 code,要看具体逻辑。

退出状态码的区间

必须在 0-255 之间,0 表示正常退出

外界将程序中断退出,状态码在 129-255

程序自身异常退出,状态码一般在 1-128

假如写代码指定的退出状态码时不在 0-255 之间,例如: exit(-1),这时会自动做一个转换,最终呈现的状态码还是会在 0-255 之间。我们把状态码记为 code,当指定的退出时状态码为负数,那么转换公式如下:256 – (|code| % 256)

审核编辑:彭静
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 程序
    +关注

    关注

    117

    文章

    3850

    浏览量

    85775
  • 容器
    +关注

    关注

    0

    文章

    546

    浏览量

    23085
  • 代码
    +关注

    关注

    30

    文章

    4986

    浏览量

    74656

原文标题:理解 Docker 容器退出码

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    双屏蔽网线安装的6个致命错误,第3个最常见

    双屏蔽网线性能强大,但如果安装不规范,不仅发挥不出优势,还可能比普通网线更差!以下是施工中最常见的6个错误: 错误1:屏蔽层没有接地 这是最最最常见的错误! 屏蔽层如果不接地,它就变成了一根"天线
    的头像 发表于 05-27 10:12 110次阅读

    Labview 主程序退出时,使用子面板插入Vi如何退出

    Labview 主程序退出时,使用子面板插入Vi如何退出? 子面板内运行的Vi会不会触发前面板关闭事件?
    发表于 04-10 10:49

    Linux新手最常踩的10个命令坑介绍

    最新的Linux内核特性(kernel 6.x系列)和常见发行版环境(Ubuntu 24.04 LTS、RHEL 9.4、CentOS Stream 10),系统梳理新手最常踩的10个命令坑,帮助读者建立正确的操作习惯和风险意识。
    的头像 发表于 04-09 10:11 328次阅读

    高压变频器最常见的用途有哪些?

    延长设备使用寿命。以下是高压变频器最常见的几类用途及其技术特点的详细分析: 一、电力行业的革命性应用 在火力发电厂中,高压变频器主要应用于锅炉给水泵、引风机、送风机等关键设备。以某600MW机组为例,采用高压变频器
    的头像 发表于 03-07 07:33 790次阅读
    高压变频器<b class='flag-5'>最常见</b>的用途有哪些?

    模组介绍

    是关于扫模组的详细介绍:核心部件扫模组的核心部件包括光源、光学镜头、图像传感器以及解码芯片等。工作时,模组发出光线照射条码,通过光学镜头捕捉反射光信号并转化为
    的头像 发表于 01-24 00:05 1074次阅读
    扫<b class='flag-5'>码</b>模组<b class='flag-5'>介绍</b>

    有哪些常见的二维模组类型?

    二维模组是集成了扫描引擎、解码芯片、光学组件的核心模块(也叫二维模块),可直接嵌入自助终端、工业PDA、智能闸机等设备,实现二维的快速识别与数据传输。其常见类型可按安装方式、扫描
    的头像 发表于 01-24 00:00 1097次阅读
    有哪些<b class='flag-5'>常见</b>的二维<b class='flag-5'>码</b>模组类型?

    常见3D打印材料介绍及应用场景分析

    3D打印材料种类丰富,不同材料性能差异明显。本文介绍PLA、ABS、PETG等常见3D打印材料的特点与应用场景,帮助读者了解3D打印用什么材料更合适,为选材提供基础参考。
    的头像 发表于 12-29 14:52 1162次阅读
    <b class='flag-5'>常见</b>3D打印材料<b class='flag-5'>介绍</b>及应用场景分析

    程序员最常见谎言

    了。 28我已经测试过了,这个功能没问题,可以上线了。 29别担心,这个问题很快就能解决。 30代快写完了,已经完成 90% 了 。 希望大家对程序员多一些容忍以及谅解! 各位程序员你们都被我说中了哪些?说说你们的观点
    发表于 12-10 08:24

    扫镭射雕用什么扫枪?

    在电子制造、汽车零部件等行业,镭射雕(DPM常见形式)因耐磨、耐高温的特性成为产品追溯的核心标识。但金属、塑料等材质的反光、曲面凹凸,加上镭雕可能存在的模糊、低对比度问题,让普
    的头像 发表于 11-20 15:30 988次阅读
    扫镭射雕<b class='flag-5'>码</b>用什么扫<b class='flag-5'>码</b>枪?

    Jtti Linux操作系统最常见的10大优势

    。以下是Linux操作系统最常见的十大优势: 1. 开源自由 ? Linux的开源性质是其最大的优势之一。任何人都可以自由地查看、修改和分发其源代码。这意味着用户不仅可以根据自己的需求进行定制,还可以避免被锁定在某些专有软件的限制中。Linux的自由
    的头像 发表于 11-06 15:32 546次阅读

    远景达固定式扫器、二维设备有哪些行业应用

    在物联网技术加速渗透的今天,固定式扫器、二维设备已成为各行业数字化转型的“刚需装备”。作为深耕物联网自动识别领域二十五余载的高新技术企业,深圳远景达(RAKINDA)推出的扫
    的头像 发表于 11-05 15:27 576次阅读
    远景达固定式扫<b class='flag-5'>码</b>器、二维<b class='flag-5'>码</b>扫<b class='flag-5'>码</b>设备有哪些行业应用

    什么是PDA扫出入库系统?功能介绍与真实应用体验

    PDA扫出入库系统广泛应用于仓储、物流、制造、电商等行业,具备扫入库、出库、盘点、调拨、RFID批量识别等功能。相比传统人工方式,它能显著提升效率和准确率,但也存在成本与培训的门槛。本文详细解析系统功能、优缺点及适用行业,帮助企业找到最合适的出入库管理方案。
    的头像 发表于 09-09 14:36 2082次阅读
    什么是PDA扫<b class='flag-5'>码</b>出入库系统?功能<b class='flag-5'>介绍</b>与真实应用体验

    固定式扫器,用于流水线扫纸盒子上的条码进行分拣

    在电商仓储、食品日化等行业的生产分拣环节中,纸盒子作为最常见的包装载体,其分拣效率直接影响企业的物流周转速度。而固定式扫器,作为专门适配流水线场景的条码扫描设备,正凭借针对性的功能设计,成为纸盒子
    的头像 发表于 09-03 16:42 1081次阅读
    固定式扫<b class='flag-5'>码</b>器,用于流水线扫纸盒子上的条码进行分拣

    工业读器在SMT流水线上读一维或二维

    在SMT(表面贴装技术)生产流水线中,元器件的追溯与质量管控离不开对条码的精准识别。从PCB板到电阻、电容等小型元器件,每一个产品都贴有专属的一维或二维——一维多为Code128
    的头像 发表于 08-20 15:30 1256次阅读
    工业读<b class='flag-5'>码</b>器在SMT流水线上读一维<b class='flag-5'>码</b>或二维<b class='flag-5'>码</b>

    模块厂家怎么选?二维模组详解

    你是否发现,从超市自助结账的POS机到小区的智能门禁,从快递柜的取件扫到地铁闸机的乘车识别,二维模组早已渗透到生活与产业的每一个角落。作为所有扫
    的头像 发表于 08-18 15:58 1106次阅读
    扫<b class='flag-5'>码</b>模块厂家怎么选?二维<b class='flag-5'>码</b>扫<b class='flag-5'>码</b>模组详解