最近領(lǐng)導(dǎo)要求上海本地的項目需要使用進jenkins實現(xiàn)自動化部署,以便可以直接將項目移交給運維的同學(xué),減輕開發(fā)的工作量。記錄下這次爬坑的過程。
成都創(chuàng)新互聯(lián)公司專注于企業(yè)成都全網(wǎng)營銷推廣、網(wǎng)站重做改版、宛城網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5網(wǎng)站設(shè)計、商城網(wǎng)站建設(shè)、集團公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為宛城等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
一、前言
Jenkins是基于Java開發(fā)的一種持續(xù)集成工具,用于監(jiān)控持續(xù)重復(fù)的工作,功能包括:
1、持續(xù)的軟件版本發(fā)布/測試項目。
2、監(jiān)控外部調(diào)用執(zhí)行的工作。
上面是我從百科上down下來的,老實說沒看懂,這是個什么玩意啊?其實以我現(xiàn)在的理解和應(yīng)用,最多的便是部署了,其他功能待研究╮(╯_╰)╭擼主目前在上海一個不知名國企打工,我們現(xiàn)在項目的發(fā)布流程是:
1、本地或打包服務(wù)器利用maven打成war包
2、遠程或者SSH連上項目服務(wù)器
3、停掉tomcat,刪除舊包和緩存,將新打的包放進去
4、重啟tomcat。完成看似步驟簡單,其實占用了大量開發(fā)的的時間。
然后使用jenkins后:
1、點擊立即構(gòu)建,完成。什么?就點擊個按鈕就完成了,沒錯,就是個按鈕。其實在你點擊按鈕后jenkins已經(jīng)幫你把上述該走的流程后臺跑了一遍了,本次就介紹下怎么讓它后臺跑。
二、安裝構(gòu)建
本次介紹基于windows,可安裝在開發(fā)電腦或者windows server服務(wù)器
1、下載jenkins
jenkins提供多種安裝方式
1.1jenkins.msi安裝 就像我們平時安裝軟件一樣,點點點。下載地址:https://jenkins.io/download/
1.2jenkins.war 包 既然是war包,不用說大家都知道怎么啟動了,扔到tomcat就行了。下載地址:http://updates.jenkins-ci.org/download/war/
2、啟動jenkins
我個人是比較推薦1.1的安裝方式的,1.2我在使用的時候經(jīng)常遇到內(nèi)存溢出的問題,當(dāng)然內(nèi)存溢出是可以調(diào)整的,但是多出了多余的工作量不是嘛。
采用1.1的安裝方式,安裝完成后我們會在windows的服務(wù)里面看到j(luò)enkins服務(wù)的。如下圖,啟動關(guān)閉重啟直接點服務(wù)就行了。
采用1.2的的方式下載war包的話,其實有兩種啟動方式。
第一種,放到tomcat容器,
第二種,cmd進入安裝目錄,java -jar jenkins.war
3、安裝jenkins
安裝方式1.1和1.2 的流程是一樣的
jenkins默認8080端口,可以修改,方法百度。
進入http://localhost:8080/。紅色字體路徑有密碼,將密碼填上,然后下一步。
選擇插件,建議選擇官方建議插件,避免很多麻煩。
等待安裝中ing......
安裝好后看到下圖,用戶名密碼登陸用的,全名是用來顯示的。繼續(xù)下一步。
因為我要部署的是maven項目,jenkins默認的插件中是沒有maven的,首先需要安裝下。
點擊下圖插件直接安裝就行了,maven integration plugins
安裝熱部署插件Deploy to container Plugin
4、配置jenkins
我們需要配下maven的setting文件,jdk以及maven地址,setting文件一定要配,不要用它默認的,擼主因為這個沒配,出問題糾結(jié)好久。
最后Apply然后Save就行了,記得別忘了應(yīng)用保存,不然白配了。
接著我們來新建一個項目,先輸入項目名,選擇maven項目,OK
選擇源碼管理,因為我們是企業(yè)項目,不是開源,使用的SVN,選擇Subversion配置SVN
URL是你SVN地址,Credentials是賬戶密碼
然后到Pre Steps,這個東西是打包前需要什么操作,比如我們現(xiàn)在的項目需要拷貝log4j.xml文件等等,根據(jù)環(huán)境可以寫windows或者Shell腳本
沒有操作的話,就不用配了。
貼出我的腳本給大家參考,相關(guān)部分我用XXX替代
@echo off rem 設(shè)置變量 :: APP.XXX app.XXX代碼的本地跟目錄 set APP.XXX="D:\svn\svn.173.X.X.X\app.XXX\" ::home.omm的log4j.xml 變量START :: HOME_OMM_LOG4J_GOALS_PATH 存放home.omm的log4j.xml的路徑 set HOME_OMM_LOG4J_GOALS_PATH="D:\svn\svn.173.X.X.X\app.XXX\src\home.omm\src\main\resources" ::HOME_OMM_LOG4J home.omm的log4j.xml測試環(huán)境的路徑 set HOME_OMM_LOG4J="D:\svn\svn.173.X.X.X\app.XXX\config\home.omm\sh_test\resources" ::home.omm的log4j.xml 變量END ::home.weixin的變量START :: HOME_WEIXIN_LOG4J_GOALS_PATH 存放home.weixin的log4j.xml的路徑 set HOME_WEIXIN_LOG4J_GOALS_PATH="D:\svn\svn.173.X.X.X\app.XXX\src\home.weixin\src\main\resources" ::HOME_WEIXIN_LOG4J home.weixin的log4j.xml測試環(huán)境的路徑 set HOME_WEIXIN_LOG4J="D:\svn\svn.173.X.X.X\app.XXX\config\home.weixin\sh_test\resources" :: HOME_WEIXIN_CONFIG.JS_GOALS_PATH 存放home.weixin的config.js的路徑 set HOME_WEIXIN_CONFIG.JS_GOALS_PATH="D:\svn\svn.173.X.X.X\app.XXX\src\home.weixin\src\main\webapp\module\js" ::HOME_WEIXIN_CONFIG.JS home.omm的log4j.xml測試環(huán)境的路徑 set HOME_WEIXIN_CONFIG.JS="D:\svn\svn.173.X.X.X\app.XXX\config\home.weixin\sh_test\webapp\module\js" ::home.weixin的變量END ::service的變量START :: SERVICE_LOG4J_GOALS_PATH 存放service的log4j.xml的路徑 set SERVICE_LOG4J_GOALS_PATH="D:\svn\svn.173.X.X.X\app.XXX\src\service\src\main\resources" ::SERVICE_LOG4J service的log4j.xml測試環(huán)境的路徑 set SERVICE_LOG4J="D:\svn\svn.173.X.X.X\app.XXX\config\service\sh_test\resources" :: SERVICE_APPLICATION_RESOURCES_ALL_GOALS_PATH 存放application-resources-all.xml的路徑 set SERVICE_APPLICATION_RESOURCES_ALL_GOALS_PATH="D:\svn\svn.173.X.X.X\app.XXX\src\service\src\main\resources\config\spring" :: SERVICE_APPLICATION_RESOURCES_ALL application-resources-all.xml測試環(huán)境的路徑 set SERVICE_APPLICATION_RESOURCES_ALL="D:\svn\svn.173.X.X.X\app.XXX\config\service\sh_test\resources\config\spring" ::service的變量END ::service.refresh的變量START :: SERVICE_REFRESH_LOG4J_GOALS_PATH 存放service.refresh的log4j.xml的路徑 set SERVICE_REFRESH_LOG4J_GOALS_PATH="D:\svn\svn.173.X.X.X\app.XXX\src\service.refresh\src\main\resources" ::SERVICE_REFRESH_LOG4J service的log4j.xml測試環(huán)境的路徑 set SERVICE_REFRESH_LOG4J="D:\svn\svn.173.X.X.X\app.XXX\config\service.refresh\sh_test\resources" :: SERVICE_REFRESH_APPLICATION_RESOURCES_ALL_GOALS_PATH 存放application-resources-all.xml的路徑 set SERVICE_REFRESH_APPLICATION_RESOURCES_ALL_GOALS_PATH="D:\svn\svn.173.X.X.X\app.XXX\src\service.refresh\src\main\resources\config\spring" :: SERVICE_REFRESH_APPLICATION_RESOURCES_ALL application-resources-all.xml測試環(huán)境的路徑 set SERVICE_REFRESH_APPLICATION_RESOURCES_ALL="D:\svn\svn.173.X.X.X\app.XXX\config\service.refresh\sh_test\resources\config\spring" ::service.refresh的變量END ::判斷home.omm的log4j.xml文件是否存在 if exist %HOME_OMM_LOG4J_GOALS_PATH%\log4j.xml (del %HOME_OMM_LOG4J_GOALS_PATH%\log4j.xml) cd %HOME_OMM_LOG4J_GOALS_PATH% copy %HOME_OMM_LOG4J%\log4j.xml log4j.xml ::判斷home.weixin的log4j.xml文件是否存在 if exist %HOME_WEIXIN_LOG4J_GOALS_PATH%\log4j.xml (del %HOME_WEIXIN_LOG4J_GOALS_PATH%\log4j.xml) cd %HOME_WEIXIN_LOG4J_GOALS_PATH% copy %HOME_WEIXIN_LOG4J%\log4j.xml log4j.xml ::判斷home.weixin的config.js文件是否存在 if exist %HOME_WEIXIN_CONFIG.JS_GOALS_PATH%\config.js (del %HOME_WEIXIN_CONFIG.JS_GOALS_PATH%\config.js) cd %HOME_WEIXIN_CONFIG.JS_GOALS_PATH% copy %HOME_WEIXIN_CONFIG.JS%\config.js config.js ::判斷service的log4j.xml文件是否存在 if exist %SERVICE_LOG4J_GOALS_PATH%\log4j.xml (del %SERVICE_LOG4J_GOALS_PATH%\log4j.xml) cd %SERVICE_LOG4J_GOALS_PATH% copy %SERVICE_LOG4J%\log4j.xml log4j.xml ::判斷service的application-resources-all.xml文件是否存在 if exist %SERVICE_APPLICATION_RESOURCES_ALL_GOALS_PATH%\application-resources-all.xml (del %SERVICE_APPLICATION_RESOURCES_ALL_GOALS_PATH%\application-resources-all.xml) cd %SERVICE_APPLICATION_RESOURCES_ALL_GOALS_PATH% copy %SERVICE_APPLICATION_RESOURCES_ALL%\application-resources-all.xml application-resources-all.xml ::判斷service.refresh的log4j.xml文件是否存在 if exist %SERVICE_REFRESH_LOG4J_GOALS_PATH%\log4j.xml (del %SERVICE_REFRESH_LOG4J_GOALS_PATH%\log4j.xml) cd %SERVICE_REFRESH_LOG4J_GOALS_PATH% copy %SERVICE_REFRESH_LOG4J%\log4j.xml log4j.xml ::判斷service.refresh的application-resources-all.xml文件是否存在 if exist %SERVICE_REFRESH_APPLICATION_RESOURCES_ALL_GOALS_PATH%\application-resources-all.xml (del %SERVICE_REFRESH_APPLICATION_RESOURCES_ALL_GOALS_PATH%\application-resources-all.xml) cd %SERVICE_REFRESH_APPLICATION_RESOURCES_ALL_GOALS_PATH% copy %SERVICE_REFRESH_APPLICATION_RESOURCES_ALL%\application-resources-all.xml application-resources-all.xml exit
Build編譯了,指定pom位置,以及mvn命令,對了高級里面還可以配置workspace,不配默認在jenkins安裝目錄中
構(gòu)建后操作,就是包打好了放在哪。選擇下圖
本次構(gòu)建后操作,使用的是tomcat的熱部署,熱部署可以參考我之前的文章:Tomcat7的熱部署
WAR/EAR:war包的地址
Context:是部署后的包名
UserName/Password是指熱部署tomcat的賬號/密碼
URL:tomcat的界面,如:http://172.16.101.71:8180/
5、開始構(gòu)建
講了那么多,終于到了最后了,一個按鈕的操作終于到了,返回jenkins首頁就可以看到我們的項目了。
構(gòu)建后點擊左下角構(gòu)建執(zhí)行狀態(tài)中可以看到我們的項目在構(gòu)建中。點擊項目名進入
選擇Console就能看到我們構(gòu)建過程中打印出來的日志或者錯誤信息了。
三、存在的問題
jenkins角色問題,既然是發(fā)布就涉及到生產(chǎn)環(huán)境,不能所有用戶都有部署生產(chǎn)環(huán)境的權(quán)限吧,如果誰不小心點了下。那后果.....不敢相信。
解決:安裝Role-based Authorization Strategy插件,其余步驟參考:http://www.cnblogs.com/zz0412/p/jenkins_jj_14.html 不在詳述。
tomcat熱部署的問題,deploy幾次之后出現(xiàn)內(nèi)存上漲溢出,停止運行或者報錯的問題,網(wǎng)上查了下是熱部署本身的問題,正在尋求解決辦法ing.....。
解決:tomcat熱部署本身存在問題,生產(chǎn)環(huán)境一般不會采用熱部署的方式。目前我這邊測試環(huán)境因為使用的是windows server 2008系統(tǒng),所以采用的是熱部署的方式,問題依舊存在,但是我看過一個帖子是說可以使用Windows 批處理命令的方式解決,就是bat命令,不過我還未深入研究過。生產(chǎn)環(huán)境Linux系統(tǒng),目前我使用Publish Over SSH 插件,具體步驟是配置中加入下圖步驟。
1、在系統(tǒng)管理-》系統(tǒng)設(shè)置里找到Publish over SSH然后輸入:
2、配置Post Steps
這里還是接著上面的項目,這個配置得安裝了上面的插件后才會顯示!
Transfer SetSource files:表示要上傳的本地的war包及路徑,可到工作空間去看
Remove prefix:表示要上傳時要去除的文件夾,即只上傳war包
remote driectory:即表示執(zhí)行時的路徑,相當(dāng)于把war包上傳到這里了
exec commad:要執(zhí)行的命令
如圖,會將war包放到home/admin文件夾,接著我會執(zhí)行我寫的Shell命令。主要涉及,停止tomcat,備份原war包,刪除webapp下原war包,將home/admin下的新war包拷進來,啟動tomcat,然后就完成了。這樣就避免了熱部署內(nèi)存溢出導(dǎo)致服務(wù)器崩潰的問題了。
腳本參考:
#!/bin/sh #defined TOMCAT_HOME="/usr/java/tomcat/apache-tomcat-7.0.67/" ID=`ps -ef | grep java | grep tomcat|awk '{print $2}'` echo $ID echo "kill tomcat" kill -9 $ID echo "remover war file" cd "$TOMCAT_HOME"/webapps rm -rf JavaWeb-0.0.1-SNAPSHOT rm -rf JavaWeb-0.0.1-SNAPSHOT.war echo "copy war to webapp" cd /home/lin cp JavaWeb-0.0.1-SNAPSHOT.war "$TOMCAT_HOME"/webapps cd "$TOMCAT_HOME"/bin echo "start tomcat" ./startup.sh
Deploy插件問題,上文中使用的Deploy to container Plugin插件來實現(xiàn)熱部署,但是deploy插件限制一個工程只能部署一個war包,我的項目是,一個工程前后端分離的兩個war,總不能新建兩個項目構(gòu)建兩次吧, ̄へ ̄。
解決:熱部署盡量不要使用,測試環(huán)境暫時使用的話,我目前是,新建兩個工程,每次只編譯一個war包。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。