k3s 貌似不会向要终止的 pod 发送 SIGTERM - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Kawa
V2EX    Kubernetes

k3s 貌似不会向要终止的 pod 发送 SIGTERM

  •  
  •   Kawa 2023-01-17 00:06:32 +08:00 via Android 2401 次点击
    这是一个创建于 1003 天前的主题,其的信息可能已经有所发展或是发生改变。

    按照 k8s 的文档, 如果没有指定的话, k8s 应该会向要终止的 pod 默认发一个 SIGTERM 才对, 结果每次我的 pod 都会被超时强杀.
    然后我自己起了个 alpine 放个 sh 脚本试了一下, 发现确实完全没有收到 SIGTERM, 手动用 kill 发是可以收到的, 这时我怀疑 k3s 根本就没有发信号.
    我又试了一下, 在 Dockerfile 里手动指定了 STOPSIGNAL, 这样才会在终止时发送信号.

    我不确定是我操作错了, 还是说这个是 k3s 的 bug, 所以来这里问一下大佬.

    11 条回复    2023-01-17 15:59:20 +08:00
    kennylam777
        1
    kennylam777  
       2023-01-17 00:59:03 +08:00
    你的 sh script 是 PID 1 ?
    baka
        2
    baka  
       2023-01-17 01:28:41 +08:00
    如果 shell 里启动了子进程,不会将 SIGTERM 信号传递给子进程,超时就被 kill -9
    可以 exec 启动你的子进程,替换 shell 进程上下文;或者 trap 显示捕获 SIGTERM
    julyclyde
        3
    julyclyde  
       2023-01-17 09:15:00 +08:00
    那是你启动方式有问题
    收到信号的是 sh

    你应该在启动脚本末尾 exec 实际干活的程序,而不是 call 实际干活的程序
    bootvue
        4
    bootvue  
       2023-01-17 09:23:25 +08:00
    tini
    littlezzll
        5
    littlezzll  
       2023-01-17 09:59:06 +08:00 via Android
    tini or dumb-init
    Kawa
        7
    < href="/member/Kawa" class="dark">Kawa  
    OP
       2023-01-17 11:06:49 +08:00 via Android
    @kennylam777 必须是, 我直接写的 ENTRYPOINT ["/ENTRYPOINT.sh"].
    我也进容器看了, 确实就是如此
    Kawa
        8
    Kawa  
    OP
       2023-01-17 11:08:37 +08:00 via Android
    @baka 我的主楼里提到了我创建了一个测试用的 pod, 里面只有几行
    trap "echo sigterm;exit" SIGTERM
    实际测试时, 除非在 dockerfile 里明确指定要发送 SIGTERM, 否则这个脚本什么都不会收到
    Kawa
        9
    Kawa  
    OP
       2023-01-17 11:10:57 +08:00 via Android
    @bootvue
    @littlezzll
    这些都试过, 确实无法收到终止信号
    除非在 dockerfile 里明确指定
    Kawa
        10
    Kawa  
    OP
       2023-01-17 11:47:35 +08:00   2
    @kennylam777 @baka @julyclyde @bootvue @littlezzll @luvroot
    谢谢各位的回复, 我在做测试镜像的时候重试了一下, 突然发现了盲点.
    原来我出问题的镜像的 base 镜像里面已经指定了 STOPSIGNAL 为 SIGQUIT, 所以我才没办法收到 SIGTERM 信号.
    这下大乌龙了
    julyclyde
        11
    julyclyde  
       2023-01-17 15:59:20 +08:00
    那你的程序收到 SIGQUIT 了吗?按说也没收到才对
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5826 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 02:41 PVG 10:41 LAX 19:41 JFK 22:41
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86