tomcat8.5+mysql5.7,JavaWeb,Docker实现

上一章中,实现了本机环境下的tomcat8.5+mysql5.7,JavaWeb测试。本章试图用docker-compose实现一键部署。

文件映射相关

tomcat:

tomcat/conf/context.xml,文件,用于jndi数据库连接
tomcat/logs/,文件夹,方便查看日志文件
tomcat/webapps/projectName,项目映射

mysql

mysql/data/,文件夹,数据库数据映射

  • 如果不知道宿主机数据在何处,在mysql的bash中,show global variables like “%datadir%”;
  • 查看容器中数据库数据:1、 docker exec -t -i containerName /bin/bash 2、登录 mysql -u root -p 3、show databases;
  • 退出bash:ctrl+p+q
  • 查看容器ip:docker inspect 容器名|findstr IPAddress,如果是linux系统,findstr改为grep

mysql/logs/,文件夹,日志文件映射

可能的报错:

java.net.ConnectException: Connection refused

尝试了没有用的:

  • command: --default-authentication-plugin=mysql_native_password
  • network_mode: “host”

最终解决了,注意几点:

  • 作为容器之后tomcat与mysql不在一台机器上,tomcat之前的配置中连接数据库部分的localhost,均要改成mysql容器的容器名
  • mysql的配置文件中,bind-address=0.0.0.0需要注释掉
mysql: Ignoring the redo log due to missing MLOG_CHECKPOINT

docker ps 看了一下,mysql一直在重启。日志中有报错InnoDB: Ignoring the redo log due to missing MLOG_CHECKPOINT…

解决方案:查看映射的 mysql/data/ 文件夹下是否有 ib_logfile0 ib_logfile1 两个文件,有则删除

java.sql.SQLException: No suitable driver
  • 没有映射 tomcat/conf/context.xml
“Host ‘xxx’ is not allowed to connect to
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值