最初在tomcat上部署web應用的方式,是經過maven的maven-compiler-plugin插件先打成war包,再將war包複製到tomcat的webapps目錄下,後來用上了tomcat7-maven-plugin插件,能夠直接在maven上編譯,打包,部署一次性完成,這個方法的關鍵是在tomcat上建立一個用戶帳號,而後maven插件用此帳號和密碼來執行在線部署。 本次實踐中,咱們要動手製做一個鏡像,這個鏡像run起來後是個tomcat server,這個server支持maven插件在線部署war應用。 首先是建立maven工程,這是一個spring mvc的工程,而且pom文件中使用了tomcat7-maven-plugin插件,工程裏面的代碼很簡單,只有一個controller,返回hello頁面,具體的代碼能夠在個人git下載,地址是:https://github.com/zq2599/blog_demos, 您也能夠指執行命令<font color="blue">git clone git@github.com:zq2599/blog_demos.git</font>來得到,下載後整個文件夾下有多個工程,本次實戰用到的是<font color="blue">loadbalancedemo</font>,以下圖下圖紅框所示,建議用intellJ Idea以maven工程的形式導入: nginx
打開工程中的pom.xml文件,能夠看到最底部的plugin節點的值:git
<plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> <configuration> <url>http://localhost:8080/manager/text</url> <server>tomcat7</server> <path>/${project.artifactId}</path> <update>true</update> </configuration> </plugin>
代碼方面就先到這裏,接下來咱們開始製做docker鏡像文件了,讓咱們先把準備工做作好:github
這個改動的用處是將get請求中的參數作UTF-8編碼,這樣咱們就能在瀏覽器的地址欄直接輸入中文參數了,改動後節點變成了:web
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8" />
<role rolename="manager-gui"/> <role rolename="manager-script"/> <user username="account001" password="password001" roles="manager-gui,manager-script"/>
修改後的效果以下圖,紅框中是新增的內容: spring
有了這些配置,就能用account001帳號在對應的tomcat上進行在線部署操做了;docker
好了,準備工做結束,咱們能夠開始作docker鏡像文件了,其實作鏡像很簡單,就是作好Dockerfile文件,再經過docker命令執行這個文件,就能生成鏡像了,咱們在image_tomcat目錄下用編輯器新增一個文件,文件名"Dockerfile",內容以下:shell
# First docker file from bolingcavalry # VERSION 0.0.1 # Author: bolingcavalry #基礎鏡像 FROM tomcat:7.0.77-jre8 #做者 MAINTAINER BolingCavalry <zq2599@gmail.com> #定義工做目錄 ENV WORK_PATH /usr/local/tomcat/conf #定義要替換的文件名 ENV USER_CONF_FILE_NAME tomcat-users.xml #定義要替換的server.xml文件名 ENV SERVER_CONF_FILE_NAME server.xml #刪除原文件tomcat-users.xml RUN rm $WORK_PATH/$USER_CONF_FILE_NAME #複製文件tomcat-users.xml COPY ./$USER_CONF_FILE_NAME $WORK_PATH/ #刪除原文件server.xml RUN rm $WORK_PATH/$SERVER_CONF_FILE_NAME #複製文件server.xml COPY ./$SERVER_CONF_FILE_NAME $WORK_PATH/
以上就是Dockerfile的所有內容,幾個關鍵點以下:apache
打開電腦的命令行,進入image_tomcat目錄,這個目錄下只有這三個文件: 瀏覽器
執行命令:tomcat
docker build -t bolingcavalrytomcat:0.0.1 .
執行中會有相似輸出:
執行完畢後,輸入docker images能夠查看當前本機的鏡像,以下圖,能夠看到新增的鏡像: 有了鏡像,執行下面的命令就能夠啓動tomcat了:
docker run --name=tomcat001 -p 8080:8080 -e TOMCAT_SERVER_ID=tomcat_server_001 -idt bolingcavalrytomcat:0.0.1
參數-e TOMCAT_SERVER_ID=tomcat_server_001的意思是在容器中設置了環境變量TOMCAT_SERVER_ID,值是tomcat_server_001 這時候再執行docker ps命令,能夠看到啓動的容器:
用瀏覽器訪問localhost:8080,能夠看到熟悉的頁面:
如今tomcat也啓動了,代碼也寫好了,能夠試試在線部署了麼?別急,還差最後一步,打開maven的安裝目錄,在conf目錄下找到settings.xml文件,打開後在servers節點添加如下內容:
<server> <id>tomcat7</id> <username>account001</username> <password>password001</password> </server>
這就是在tomcat的tomcat-users.xml文件中配置的用戶和密碼,這樣執行maven插件的時候就能今後處取得對應的用戶名和密碼去tomcat上作操做了。
回到以前的那個web工程,用命令行進入pom.xml文件所在的目錄,執行命令
mvn clean package -U -Dmaven.test.skip=true tomcat7:redeploy
執行結果以下:
ok,tomcat7-maven-plugin插件已經幫咱們把war部署到docker容器上去了,在瀏覽器輸入
http://localhost:8080/loadbalancedemo/hello?name=張三
能夠看到以下效果:
藍色字體的tomcat_server_001就是咱們啓動tomcat容器時經過-e參數設置的環境變量,在HelloController中被成功取出並展現到jsp頁面上,代碼以下圖:
以上經過對tomcat官方鏡像的一些文件操做,獲得了咱們本身製做的鏡像文件,並結合mvn插件實現了web應用在線部署在tomcat容器上的效果,下一次實戰,咱們會接着這個例子啓動兩個tomcat容器,再在前面放一個nginx,來實現負載均衡,過程當中會學到docker compose和link的相關知識。