pipeline timeout关于Body did not finish within grace period; terminating with extreme prejudice超时不退出

事件背景

触发了一个扫描,然后需要等待扫描结束,获取扫描的结果。所以些了如下的代码。
每十秒钟查询一下扫描的结果,如果没有结果,则继续,直到返回true,外层是有一个30分钟超时,测试的时候换成了两分钟。

结果发现,两分钟后,并没有超时退出。google后发现,超时之后,会跑到timeout内部的try catch,而不是外部的catch。所以执行的是print(err) return false,自然的就继续在waitUntil内部执行了。

timeout(2){
            waitUntil{
                try {
                    sleep 10
                    //查询扫描执行结果 
                    sh '''
                       xxx.sh
                       '''
                    return true
                }
                catch (err){
                    print(err)
                    return false
                }
            }
        }

解决办法

通过打印print(ex.getMessage())获取超时异常的名称,准确捕获后,不返回bool值,就会抛出异常,退出timeout。

timeout(2){
            waitUntil{
                try {
                    sleep 10
                    //查询扫描执行结果 
                    sh '''
                       xxx.sh
                       '''
                    return true
                }
                catch (org.jenkinsci.plugins.workflow.steps.FlowInterruptedException ex){
                    //不返回bool值,显示抛出错误
                    echo "超时"
                }
                catch (ex){
                    print(ex)
                    return false
                }
            }
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值