收藏本站 收藏本站
積木網首頁 - 軟件測試 - 常用手冊 - 站長工具 - 技術社區
首頁 > 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號
手游棋牌游戏运营
重庆时时个位走势图 三肖期期开奖结果 时时路珠统计软件 福建时时彩开奖号码 快乐十分最大遗漏 加拿大28结果预测大神网 内蒙古时时计划软件手机版式 河南快三开奖结果50期 北京赛app机器人 红姐图库免费大全 黑龙江时时号码走势 九霄公式计算方法公开 黑龙江快乐十分走势图50 pk赛车一天180期 查河南22选5开奖结果 北京pk计划一期单期版