亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

宝清县| 政和县| 武强县| 万盛区| 深州市| 黎城县| 台湾省| 聂拉木县| 得荣县| 山阴县| 德格县| 商河县| 沂水县| 哈密市| 东阳市| 中卫市| 红桥区| 楚雄市| 军事| 临高县| 九台市| 桂阳县| 阜新市| 汝城县| 五常市| 易门县| 江华| 平塘县| 昌邑市| 阳朔县| 汤原县| 扎鲁特旗| 翁牛特旗| 张家川| 和政县| 宣汉县| 武宁县| 扎囊县| 邵阳县| 彰化县| 通州市|