收藏本站 收藏本站
積木網首頁 - 軟件測試 - 常用手冊 - 站長工具 - 技術社區
首頁 > shell編程 > 正文

首頁 - PHP - 數據庫 - 操作系統 - 游戲開發 - JS - Android - MySql - Redis - MongoDB - Win8 - Shell編程 - DOS命令 - jQuery - CSS樣式 - Python - Perl

Access - Oracle - DB2 - SQLServer - MsSql2008 - MsSql2005 - Sqlite - PostgreSQL - node.js - extjs - JavaScript vbs - Powershell - Ruby

淺談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腳本異常退出問題定位就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持積木網。

Linux查找處理文件名后包含空格的文件(兩種方法)
當Linux下文件名中出現空格這類特殊情況話,如何查找或確認那些文件名后有空格呢?又怎么批量替換處理掉這些空格呢?方法1:輸入文件名后使用Tab

shell編程跨服務器備份文件
本文實例為大家分享了shell跨服務器備份文件的具體代碼,供大家參考,具體內容如下需求:查詢某個文件夾下的所有文件,將文件修改時間小于當前時

通過Spring Shell 開發 Java 命令行應用
提到Java,大家都會想到Java在服務器端應用開發中的使用。實際上,Java在命令行應用的開發中也有一席之地。在很多情況下,相對于圖形用戶界面來說

本周排行

更新排行

強悍的草根IT技術社區,這里應該有您想要的! 友情鏈接:b2b電子商務
Copyright © 2010 Gimoo.Net. All Rights Rreserved  京ICP備05050695號
手游棋牌游戏运营
beplay体育app下载ios 微信十元猜订单号大小 重庆时时开奖号码查询结果是 欢乐生肖官方开奖 t6网站 金库LG 九城娱乐平台怎么样 赛车北京pk10现场直播 黑龙江时时加奖 时时彩后二8码 欢乐斗地主和好友就2人 香港无错36码中特 时时彩官方最快开奖 彩票转让合同 宝贝全计划苹果版 正规牛牛