您好,登錄后才能下訂單哦!
綜上所述,一個通過svn的鉤子結合的Jenkins獨有的特性,來構建這個網站代碼上線的架構吧!不多啰嗦了。
安裝svn 、 Jenkins的安裝請看博客的鏈接
http://zzxtbl.blog.51cto.com/7620672/1744529 #svn 安裝
http://zzxtbl.blog.51cto.com/7620672/1656380 #jenkins的安裝
svn鉤子腳本的配置(在你當前svn的當前的版本庫下修改)
/svn/test/hooks/post-commit
REPOS="$1" REV="$2" LANG=en_US.UTF-8 LOGFILE=/var/log/svn.log # 鉤子腳本的日志 # 腳本的標準輸出和標準錯誤輸出都打印到日志文件里 exec 1>>"$LOGFILE" exec 2>&1 SVNLOOK=/usr/bin/svnlook TIME=$(date "+%Y-%m-%d %H:%M:%S") AUTHOR=$($SVNLOOK author -r $REV "$REPOS") #提交作者 CHANGEDDIRS=$($SVNLOOK dirs-changed $REPOS) #修改的目錄集合 MESSAGE=$($SVNLOOK log -r $REV "$REPOS") #提交時的備注信息,不建議用中文 # SVN客戶端配置,需要自行修改********************************** CLIENTSVNROOT=/data/www #WEB服務器的代碼根目錄 SVNUSER="tiantian" SVNPASSWD="123456" #************************************************************** function myecho() { echo "$TIME" "$*" } myecho "**************************************************************" myecho "提交版本:$REV 作者:$AUTHOR" myecho "提交備注:$MESSAGE" myecho "修改目錄:$(echo $CHANGEDDIRS | tr '\n' ' ')" MASTERDIR=$(echo "$CHANGEDDIRS" | head -1) #CHANGEDDIRS里的主目錄 # 遍歷提交的代碼目錄,同步到WEB服務器上 while [ "$CHANGEDDIRS" != "" ];do PROJECT=$(echo $MASTERDIR | awk -F / '{print $1}') # 判斷項目文件夾 if [ "$PROJECT" == "php" ];then myecho myecho "項目:$PROJECT 同步目錄:$MASTERDIR" myecho "同步 $MASTERDIR 到 $CLIENT1:$CLIENTSVNROOT/$MASTERDIR" # 無密碼ssh連接到客戶端服務器,執行svn up SVN=/usr/bin/svn svn up --non-interactive --username $SVNUSER --password $SVNPASSWD /$CLIENTSVNROOT/$MASTERDIR if [ $? -eq 0 ] then /usr/bin/rsync -az --delete $CLIENTSVNROOT /tmp/ #臨時目錄 fi elif [ "$PROJECT" == "tianshi" ];then myecho myecho "項目:$PROJECT 同步目錄:$MASTERDIR" myecho "同步 $MASTERDIR 到 $CLIENT2:$CLIENTSVNROOT/$MASTERDIR" svn up --non-interactive --username $SVNUSER --password $SVNPASSWD /$CLIENTSVNROOT/$MASTERDIR if [ $? -eq 0 ] then /usr/bin/rsync -az --delete $CLIENTSVNROOT /tmp/ #臨時目錄 fi else : fi # 在目錄集合里刪除已經同步好的目錄 CHANGEDDIRS=$(echo "$CHANGEDDIRS" | grep -v "^$MASTERDIR") # 獲取新的需要同步的主目錄 MASTERDIR=$(echo "$CHANGEDDIRS" | head -1) done 別忘了給鉤子授權 chmod 755 post-commit
3.關于臨時目錄的要授予Apache權限和svn提交文件克隆
chown apache:apache -R /data/www
chown apache:apache -R /tmp/
chown apache:apache -R /var/log
svn提交文件克隆命令
svn co svn://192.168.40.128 --username tiantian --password 123456 /data/www
不操作這條命令會造成沒權限法提交
2016-01-14 03:35:20 項目:php 同步目錄:php/
2016-01-14 03:35:20 同步 php/ 到 :/data/www/php/
Skipped '/data/www/php'
4.版本控層已經寫好了,看效果吧
5.jenkins項目的創建
主要是兩個方面,一是源碼管理,二是構建觸發器,配置信息如下(其中* * * * *,即表示每分鐘檢測一遍代碼,若發現有更新則自動觸發構造項目)
6. Jenkins每次構建數據的同事執行同步的數據(rsync軟件同步)
查看構建的結果
7.查看測試結果
總結:
svn+jenkins構建可持續化的程序。重點控制的環節在于svn版本的控制。
總結有些很簡介。后續再添加吧。我也是小白。黑黑!!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。