Docker下Tomcat容器中使用Mysql的方法
在這里我們使用Tomcat容器來運(yùn)行war包,不過作為一個(gè)網(wǎng)站一個(gè)程序,如果需要用到數(shù)據(jù)庫的,那么Tomcat容器中如何連接Mysql呢?
已經(jīng)pull了tomcat和mysql鏡像,可以使用docker的連接系統(tǒng)(–link)連接多個(gè)容器方式解決tomcat容器中使用mysql
[root@izbp1b5k5bjps0dw8owk7tz ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE tomcat latest 2d084b11164d 7 days ago 463MB mysql 5.7.22 66bc0f66b7af 2 weeks ago 372MB [root@izbp1b5k5bjps0dw8owk7tz ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES [root@izbp1b5k5bjps0dw8owk7tz ~]#
先啟動(dòng)mysql
docker run --name mysql -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.221
命令說明:
•–name:自定義別名
•-p 3306:3306:將容器的 3306 端口映射到主機(jī)的 3306 端口
•-v /home/mysql/conf:/etc/mysql/conf.d:將主機(jī) /home/mysql/conf/my.cnf 掛載到容器的 /etc/mysql/my.cnf
•-v /home/mysql/data:/var/lib/mysql :將主機(jī) /home/mysql/data 目錄掛載到容器的 /var/lib/mysql
•-e MYSQL_ROOT_PASSWORD=123456:初始化 root 用戶的密碼
•-d:以守護(hù)進(jìn)程方式運(yùn)行
注:運(yùn)行的mysql暴露端口(-p 3306:3306),如果在生產(chǎn)環(huán)境,為了安全也可以不向外暴露端口,之后在運(yùn)行tomcat容器可以通過(--link)指定容器來使用mysql
運(yùn)行tomcat
docker run --name tomcat -p 8080:8080 -v /etc/localtime:/etc/localtime:ro -v /home/tomcat/logs:/usr/local/tomcat/logs -d --link mysql:db tomcat1
命令說明:
•–name:自定義別名
•-p 8080:8080:將容器的 8080 端口映射到主機(jī)的 8080 端口
•-v /etc/localtime:/etc/localtime:ro:掛載localtime文件到容器內(nèi),保證兩者所采用的時(shí)區(qū)是一致的
•-v /home/tomcat/logs:/usr/local/tomcat/logs:將主機(jī) /home/tomcat/logs 目錄掛載到容器的 /usr/local/tomcat/logs
•-d:以守護(hù)進(jìn)程方式運(yùn)行
•–link mysql:db:告訴當(dāng)前容器需要使用mysql容器,并命名為db
這樣就可以在tomcat容器中通過db訪問mysql了
附: Java中數(shù)據(jù)庫連接參考語句:
jdbc_url=jdbc:mysql://db:3306/databasename?useUnicode=true&characterEncoding=utf8 [root@izbp1b5k5bjps0dw8owk7tz mysql]# docker run --name mysql -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.22 c7378e84c19b0baa448d687c089ef8cc0ce058f71b2f79d8801fc9be7bd2c5b4 [root@izbp1b5k5bjps0dw8owk7tz mysql]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES c7378e84c19b mysql:5.7.22 "docker-entrypoint.s…" 6 seconds ago Up 5 seconds 0.0.0.0:3306->3306/tcp mysql [root@izbp1b5k5bjps0dw8owk7tz logs]# docker run --name tomcat -p 8080:8080 -v /etc/localtime:/etc/localtime:ro -v /home/tomcat/logs:/usr/local/tomcat/logs -d --link mysql:db tomcat 1458f532ef36e12ad49b4a5d90ff9b38abed00986094225354594a5fe7591362 [root@izbp1b5k5bjps0dw8owk7tz logs]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 1458f532ef36 tomcat "catalina.sh run" 3 seconds ago Up 2 seconds 0.0.0.0:8080->8080/tcp tomcat c7378e84c19b mysql:5.7.22 "docker-entrypoint.s…" About a minute ago Up About a minute 0.0.0.0:3306->3306/tcp mysql
總結(jié)
以上所述是小編給大家介紹的Docker中Tomcat容器使用Mysql容器的方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
聊聊kubernetes1.20用containerd替換docker(shim)的問題
這篇文章主要介紹了kubernetes1.20用containerd替換docker(shim),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03詳解利用Dockerfile構(gòu)建mysql鏡像并實(shí)現(xiàn)數(shù)據(jù)的初始化及權(quán)限設(shè)置
本篇文章主要介紹了詳解利用Dockerfile構(gòu)建mysql鏡像并實(shí)現(xiàn)數(shù)據(jù)的初始化及權(quán)限設(shè)置 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06如何在docker中運(yùn)行springboot項(xiàng)目過程圖解
這篇文章主要介紹了如何在docker中運(yùn)行springboot項(xiàng)目過程圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06使用Docker部署MySQL 5.7&8.0主從集群的方法步驟
這篇文章主要介紹了使用Docker部署MySQL 5.7&8.0主從集群的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03