1. 程式人生 > >Docker——Tomcat容器使用Mysql容器

Docker——Tomcat容器使用Mysql容器

在這裡我們使用Tomcat容器來執行war包,不過作為一個網站一個程式,如果需要用到資料庫的,那麼Tomcat容器中如何連線Mysql呢?

已經pull了tomcat和mysql映象,可以使用docker的連線系統(–link)連線多個容器方式解決tomcat容器中使用mysql

[root@izbp1b5k5bjps0dw8owk7tz ~]# docker images
REPOSITORY           TAG                 IMAGE ID            CREATED             SIZE
tomcat               latest              2
d084b11164d 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
~]#

先啟動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

命令說明:

  • –name:自定義別名
  • -p 3306:3306:將容器的 3306 埠對映到主機的 3306 埠
  • -v /home/mysql/conf:/etc/mysql/conf.d:將主機 /home/mysql/conf/my.cnf 掛載到容器的 /etc/mysql/my.cnf
  • -v /home/mysql/data:/var/lib/mysql :將主機 /home/mysql/data 目錄掛載到容器的 /var/lib/mysql
  • -e MYSQL_ROOT_PASSWORD=123456:初始化 root 使用者的密碼
  • -d:以守護程序方式執行

注:執行的mysql暴露埠(-p 3306:3306),如果在生產環境,為了安全也可以不向外暴露埠,之後在執行tomcat容器可以通過(--link)指定容器來使用mysql

執行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 tomcat

命令說明:

  • –name:自定義別名
  • -p 8080:8080:將容器的 8080 埠對映到主機的 8080 埠
  • -v /etc/localtime:/etc/localtime:ro:掛載localtime檔案到容器內,保證兩者所採用的時區是一致的
  • -v /home/tomcat/logs:/usr/local/tomcat/logs:將主機 /home/tomcat/logs 目錄掛載到容器的 /usr/local/tomcat/logs
  • -d:以守護程序方式執行
  • –link mysql:db:告訴當前容器需要使用mysql容器,並命名為db

這樣就可以在tomcat容器中通過db訪問mysql了

附: Java中資料庫連線參考語句:

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