您好,登錄后才能下訂單哦!
這篇文章主要講解了“Docker搭建disconf環境的過程”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Docker搭建disconf環境的過程”吧!
在前兩章中,我們利用遠程或本地的鏡像,快速體驗了本地啟動disconf的過程,本章我們一起來分析和梳理整個定制和搭建過程,了解這些后,我們就能根據自己的需要來定制本地的disconf環境了。
以下兩點請注意
本機環境已經安裝了maven,并且把maven的bin目錄配置到環境變量PATH下;
編譯編譯disconf源碼時,要用到官方shell腳本,所以本次實踐的操作系統建議用linux或mac,如果用windows,有三種方法:一個是把shell改成bat腳本,一個是用虛擬機的linux,還有一種是用在docker上搭建一個maven容器,把disconf源碼放在這個容器下編譯;
首先把disconf環境依賴的所有server都列出來:
redis<無需定制,用官方鏡像>
zookeeper<無需定制,用官方鏡像>
mysql<<font color="red">定制</font>,創建庫,表,導入初始化數據>
tomcat<<font color="red">定制</font>,包含業務war包,路徑配置>
nginx<<font color="red">定制</font>,配置動靜分離,包含靜態web資源>
下一步,是理清各個server之間的依賴關系(例如tomcat上的業務要連接mysql數據庫),依賴關系如下,搞清楚了這個就知道link參數怎么寫了:
server的關系已經理清了,接下來就要開始定制mysql,tomcat,nginx這些鏡像了,首先是準備材料,disconf是個開源的應用,我們可以在git上下載最新的源碼,執行命令:
git clone git@github.com:knightliao/disconf.git
下載完畢,打開文件夾,內容如下圖:
接下來我們開始實戰把,實戰一共五個步驟,依次是: 定制mysql鏡像 -> 定制tomcat鏡像 -> 定制nginx鏡像 -> 編寫docker-compose腳本 -> docker-compose啟動
mysql定制:目的是讓容器在創建時自動執行sql腳本,創建庫和表,并導入初始化數據,在docker上實現數據庫腳本自動執行的方法可以參照《讓docker中的mysql啟動時自動執行sql》一文,這里簡單說一下步驟:
打開disconf源碼文件夾,在disconf/disconf-web/sql目錄下找到以下四個文件:
0-init_table.sql 1-init_data.sql 201512/20151225.sql 20160701/20160701.sql
新建一個目錄mysql,把上面提到的四個sql文件復制到這個目錄下,再新建一個名為install_data.sh的腳本,內容如下:
#!/bin/bash mysql -uroot -p$MYSQL_ROOT_PASSWORD <<EOF source $WORK_PATH/$FILE_0; source $WORK_PATH/$FILE_1; source $WORK_PATH/$FILE_2; source $WORK_PATH/$FILE_3;
內容很簡單,就是自動登錄mysql,密碼是docker啟動的時候傳入的環境變量,然后執行四個sql腳本文件
在mysql目錄下新建Dockerfile文件,內容如下:
# Docker image of disconf mysql # VERSION 0.0.1 # Author: bolingcavalry #基礎鏡像使用daocloud.io/library/mysql:8 FROM daocloud.io/library/mysql:8 #作者 MAINTAINER BolingCavalry <zq2599@gmail.com> #定義工作目錄 ENV WORK_PATH /usr/local/work #定義會被容器自動執行的目錄 ENV AUTO_RUN_DIR /docker-entrypoint-initdb.d #定義sql文件名 ENV FILE_0 0-init_table.sql ENV FILE_1 1-init_data.sql ENV FILE_2 20151225.sql ENV FILE_3 20160701.sql #定義shell文件名 ENV INSTALL_DATA_SHELL install_data.sh #創建文件夾 RUN mkdir -p $WORK_PATH #把數據庫初始化數據的文件復制到工作目錄下 COPY ./$FILE_0 $WORK_PATH/ COPY ./$FILE_1 $WORK_PATH/ COPY ./$FILE_2 $WORK_PATH/ COPY ./$FILE_3 $WORK_PATH/ #把要執行的shell文件放到/docker-entrypoint-initdb.d/目錄下,容器會自動執行這個shell COPY ./$INSTALL_DATA_SHELL $AUTO_RUN_DIR/ #給執行文件增加可執行權限 RUN chmod a+x $AUTO_RUN_DIR/$INSTALL_DATA_SHELL
打開終端在mysql目錄下執行以下命令,構建msql鏡像:
docker build -t conf_mysql:0.0.1 .
msql鏡像構建成功
構建tomcat鏡像時最重要的就是war包的生成,步驟如下:
創建兩個文件夾,分別設置到<font color="red">ONLINE_CONFIG_PATH</font>和<font color="red">WAR_ROOT_PATH</font>這兩個環境變量中,環境變量的設置方式在不同的操作系統下各不相同,我用的是mac,配置方式是在~/.bash_profile文件中加入以下內容(寫完記得執行source ~/.bash_profile使環境變量在當前命令行窗口生效):
ONLINE_CONFIG_PATH=/Users/zq2599/temp/201705/03/005/online-resources WAR_ROOT_PATH=/Users/zq2599/temp/201705/03/005/war export ONLINE_CONFIG_PATH export WAR_ROOT_PATH
<font color="red">/Users/zq2599/temp/201705/03/005/online-resources</font>和<font color="red">/Users/zq2599/temp/201705/03/005/war</font>都是剛剛新建的文件夾;
打開disconf的源文件的子目錄disconf-web/profile/rd,里面的文件如下圖:
把這些文件全部復制到<font color="red">ONLINE_CONFIG_PATH</font>變量對應的目錄下,在這個目錄下依次修改jdbc-mysql.properties,redis-config.properties,zoo.properties這三個文件:
jdbc-mysql.properties的改動如下圖,主要是數據url改成一個固定的名字mysqlhost,這個在docker run的時候要和link參數中的別名一致,還有就是數據庫的用戶名密碼:
redis-config.properties的改動如下圖,主要是host參數,也要和docker run時候的link參數的別名對齊,<font color="red">注意,這里要配置兩個redis</font>
zoo.properties的配置如下圖,主要是host參數,也要和docker run時候的link參數的別名對齊:
把application-demo.properties文件改名為application.properties
好了,修改參數的事情就算做完了,有了這些和link參數一致的host配置,tomcat在運行的時候就能連接上對應的容器了。
現在我們用maven來編譯和打包disconf的源碼,用終端進入disconf源碼的disconf-web子目錄,執行以下命令開始編譯和打包:
sh deploy/deploy.sh
執行完畢后,在環境變量<font color="red">WAR_ROOT_PATH</font>對應的目錄下,可以看到編譯和打包的結果,如下圖:
新建一個名叫tomcat的文件夾,把上圖中的disconf-web.war復制到這個文件夾下,再在這里新增一個server.xml文件,內容如下,用來指定tomcat服務的根路徑對應的應用:
<?xml version='1.0' encoding='utf-8'?> <Server port="8005" shutdown="SHUTDOWN"> <Listener className="org.apache.catalina.startup.VersionLoggerListener" /> <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /> <Listener className="org.apache.catalina.core.JasperListener" /> <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" /> <GlobalNamingResources> <Resource name="UserDatabase" auth="Container" type="org.apache.catalina.UserDatabase" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" pathname="conf/tomcat-users.xml" /> </GlobalNamingResources> <Service name="Catalina"> <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> <Engine name="Catalina" defaultHost="localhost"> <Realm className="org.apache.catalina.realm.LockOutRealm"> <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/> </Realm> <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true"> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log." suffix=".txt" pattern="%h %l %u %t "%r" %s %b" /> <Context path="" docBase="/usr/local/tomcat/webapps/disconf-web" debug="0" reloadable="true" crossContext="true"/> </Host> </Engine> </Service> </Server>
這個配置信息和官方tomcat中的server.xml文件相比,其實只增加了下面這一個節點的內容:
<Context path="" docBase="/usr/local/tomcat/webapps/disconf-web" debug="0" reloadable="true" crossContext="true"/>
在tomcat文件夾下新增Dockerfile文件,內容如下:
# Docker image of disconf tomcat # VERSION 0.0.1 # Author: bolingcavalry #基礎鏡像使用tomcat:7.0.77-jre8 FROM tomcat:7.0.77-jre8 #作者 MAINTAINER BolingCavalry <zq2599@gmail.com> #定義工作目錄 ENV TOMCAT_BASE /usr/local/tomcat #復制配置文件 COPY ./server.xml $TOMCAT_BASE/conf/ #復制war包 COPY ./disconf-web.war $TOMCAT_BASE/webapps/ #給配置文件增加讀權限 RUN chmod a+xr $TOMCAT_BASE/conf/server.xml #刪除默認的ROOT文件件 RUN rm -rf $TOMCAT_BASE/webapps/ROOT
看的出Dockerfile做的事情并不多,就是復制war包,復制server.xml,刪除默認的ROOT應用文件夾這些事情;
現在打開終端在tomcat目錄下執行以下命令,構建tomcat鏡像:
docker build -t conf_tomcat:0.0.1 .
tomcat鏡像構建成功!
###構建nginx鏡像###
新建一個nginx目錄,在里面新增一個nginx.conf文件,內容如下:
user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; #gzip on; #include /etc/nginx/conf.d/*.conf; upstream disconf { server tomcathost:8080; } server { listen 80; server_name localhost; access_log logs/disconf_access.log; error_log logs/disconf_error.log; location / { root /usr/local/work/html; if ($query_string) { expires max; } } location ~ ^/(api|export) { proxy_pass_header Server; proxy_set_header Host $http_host; proxy_redirect off; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Scheme $scheme; proxy_pass http://disconf; } } }
主要的配置有三點:
將默認的/etc/nginx/conf.d/*.conf配置注釋掉; 增加tomcat的host信息,“tomcathost”和后面docker run的link參數的別名保持一致; 動靜分離的配置,請求url中如果帶有api和export,nginx就把請求轉發到tomcathost:8080,其他的請求直接訪問nginx服務器的/usr/local/work/html文件夾;
在環境變量<font color="red">WAR_ROOT_PATH</font>對應的目錄下,有個html文件夾如下圖紅框位置,這是web工程全部靜態文件,把這個文件夾復制到剛才新建的nginx目錄下:
在nginx文件夾下新增Dockerfile文件,內容如下:
# Docker image of disconf nginx # VERSION 0.0.1 # Author: bolingcavalry #基礎鏡像使用nginx:stable FROM nginx:stable #作者 MAINTAINER BolingCavalry <zq2599@gmail.com> #定義工作目錄 ENV WORK_PATH /usr/local/work/html #定義nginx配置文件所在目錄 ENV NGINX_CONF_DIR /etc/nginx #定義nginx配置文件名稱 ENV NGINX_CONF_FILE_NAME nginx.conf #創建工作文件夾 RUN mkdir -p $WORK_PATH #創建nginx日志文件夾 RUN mkdir -p /etc/nginx/logs/ #復制nginx配置文件 COPY ./$NGINX_CONF_FILE_NAME $NGINX_CONF_DIR/ #復制網頁的靜態資源文件 COPY ./html $WORK_PATH/ #給配置文件增加讀權限 RUN chmod a+xr $NGINX_CONF_DIR/$NGINX_CONF_FILE_NAME
現在打開終端在nginx目錄下執行以下命令,構建nginx鏡像:
docker build -t conf_nginx:0.0.1 .
nginx鏡像構建成功!
新增一個docker-compose.yml文件(位置無所謂),內容如下:
version: '2' services: disconf_redis_1: image: daocloud.io/library/redis restart: always disconf_redis_2: image: daocloud.io/library/redis restart: always disconf_zookeeper: image: zookeeper:3.3.6 restart: always disconf_mysql: image: conf_mysql:0.0.1 environment: MYSQL_ROOT_PASSWORD: 123456 restart: always disconf_tomcat: image: conf_tomcat:0.0.1 links: - disconf_redis_1:redishost001 - disconf_redis_2:redishost002 - disconf_zookeeper:zkhost - disconf_mysql:mysqlhost restart: always disconf_nginx: image: conf_nginx:0.0.1 links: - disconf_tomcat:tomcathost ports: - "80:80" restart: always
按照我們最初梳理的依賴關系,啟動兩個redis官方鏡像,一個zookeeper官方鏡像,再啟動定制的msyql鏡像,然后tomcat啟動并通過link關聯redis,zookeeper,mysql等容器,最后是定制的nginx啟動,link關聯tomcat,并且nginx容器的80端口映射到當前電腦的80端口;
在docker-compose.yml文件所在的目錄下,執行命令:
docker-compose up -d
終端會顯示正在啟動各個容器,如下圖,每個容器的名稱會被docker-compose加上前綴和后綴:
tomcat的應用啟動需要一點時間,我們可以通過docker logs -f disconf_disconf_tomcat_1命令來查看tomcat啟動日志,disconf_disconf_tomcat_1是容器名稱,如上圖中的紅框所示。
啟動完畢后,在瀏覽器上輸入localhost,可以看見熟悉的disconf登錄頁面,用戶名admin,密碼admin,登錄進去試試吧:
感謝各位的閱讀,以上就是“Docker搭建disconf環境的過程”的內容了,經過本文的學習后,相信大家對Docker搭建disconf環境的過程這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。