在这里我们使用 Tomcat 容器来运行 war 包,不过作为一个网站一个程序,如果需要用到数据库的,那么 Tomcat 容器中如何连接 Mysql 呢?

已经 pull 了 tomcat 和 mysql 镜像,可以使用 docker 的连接系统 (--link) 连接多个容器方式解决 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 ~]#

先启动 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 \ 
--link mysql:db \
-d 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

my.cnf

[mysqld]

pid-file=/var/run/mysqld/mysqld.pid
socket=/var/run/mysqld/mysqld.sock
datadir=/var/lib/mysql
#log-error=/var/log/mysql/error.log
# By default we only accept connections from localhost
#bind-address=127.0.0.1
# Disabling symbolic-links is recommended to prevent assorted security risks

sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mysql.conf.d/

results matching ""

    No results matching ""