在这里我们使用Tomcat容器来运行war包,不过作为一个网站一个程序,如果需要用到数据库的,那么Tomcat容器中如何连接Mysql呢?
已经pull了tomcat和mysql镜像,可以使用docker的连接系统(–link)连接多个容器方式解决tomcat容器中使用mysql
1
2
3
4
5
6
7
[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
1
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
1
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中数据库连接参考语句:
1
2
3
4
5
6
7
8
9
10
11
12
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容器的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:https://blog.csdn.net/yori_chen/article/details/81009312
声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。