在这里我们使用 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/