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 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.221

命令说明:

•–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 tomcat1

命令说明:

•–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

总结

以上所述是小编给大家介绍的Docker中Tomcat容器使用Mysql容器的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值