91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

CI腳本異常退出問題的示例分析

發布時間:2021-08-04 10:07:35 來源:億速云 閱讀:104 作者:小新 欄目:開發技術

這篇文章主要介紹CI腳本異常退出問題的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

背景

在CI腳本中,使用類似如下腳本進行項目編譯的計時,但在執行過程中,有時會出現CI腳本(命名為ci.sh)未完全執行的情況:

#!/bin/bash -e

sleep_time=$1

start_time=`date "+%s"`
# do sth, this sleep would simulate project compilation
sleep $sleep_time
end_time=`date "+%s"`

process_time=`expr \( end_time - start_time \)`
echo "---- process time(sec) are: " $process_time "seconds"

# ...

這個腳本,只是模擬我們在CI中的程序,項目編譯前計時,項目編譯后再次計時,通過sleep休眠來模擬CI中項目編譯鎖消耗的時間,然后計算出消耗的時間。這個簡化的腳本邏輯很簡單,我們通過以下命令來調用:

# ./ci.sh
---- process time(sec) are: 2 seconds

這樣執行好像并不會出錯,那實際CI中為什么會出錯呢?

分析

首先,我們發現,當出現腳本未完全執行完成時,不會打印“process time(sec) are”這一句,也就是說錯誤是這句之前引起的。

另外,細心的朋友還會發現,在腳本的首行,我們給bash使用了-e參數,這個參數的作用就是,一旦shell腳本中任何一行出現了錯誤,shell腳本就停止運行。所謂的出現錯誤,也就是這行語句的返回值為非零。那么,CI腳本未完全執行的原因,很可能就是因為某一行語句出現了錯誤,導致腳本直接退出。

通過增加打印“echo $?”來打印上一行語句的執行結果,很快定位到報錯的語句在計算處理時間的這一行:

process_time=`expr \( end_time - start_time \)` 

這一行看起來十分普通,只是簡單的用終止時間減去開始時間,然后賦值給process_time。為什么會返回非0值呢?

原來,expr命令有一個小小的trick,當expr表達式中的計算結果為0時,expr命令就會返回1,而不是通常的0。在我們實際的CI任務中,一旦某個項目編譯時間非常短,在1秒鐘內完成,那么起止時間系統,其差值也就為0,因此,expr就會返回非零值,而CI腳本也會因此而退出。

以上是“CI腳本異常退出問題的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

柏乡县| 拉萨市| 天长市| 邯郸县| 砀山县| 阳西县| 康定县| 青田县| 逊克县| 梨树县| 凤庆县| 重庆市| 安庆市| 大兴区| 阿拉善左旗| 福州市| 玉屏| 利川市| 古交市| 浮梁县| 甘南县| 凤翔县| 鲜城| 七台河市| 将乐县| 登封市| 彩票| 元氏县| 永嘉县| 五华县| 长岭县| 扬中市| 郯城县| 正镶白旗| 娱乐| 包头市| 曲阳县| 乳源| 乐山市| 谢通门县| 肥乡县|