java – Docker – 将Apache Tomcat Web服务器连接到MySQL服务器

我尝试将运行在Apache Tomcat容器中的Web服务器连接到运行另一个容器的MySQL数据库.为了做到这一点,我使用Docker的链接机制.

docker run -it --name ${CONTAINER_NAME} --link db:db -p 8080:8080 -d tomcat

运行容器后,我可以看到容器已链接,环境变量已正确显示.

为了将在Tomcat容器中运行的Web应用程序连接到数据库,我使用以下配置文件:

<Context>
  <Resource
    name="jdbc/MYDB"
    type="javax.sql.DataSource"
    auth="Container"
    username="user"
    password="password"
    driverClassName="com.mysql.jdbc.Driver"
    url="jdbc:mysql://${DB_PORT_3306_TCP_ADDR}:${DB_PORT_3306_TCP_PORT}/epcis?autoReconnect=true">
  </Resource>
</Context>

现在的问题是我无法建立与数据库的连接,因为在Tomcat环境中无法识别Docker公开的环境变量.

有一种方法可以让Docker公开的这些环境变量对Apache Tomcat环境可见吗?

解决方法:

你能使用db的dns声明和硬编码引用吗?我认为/ etc / hosts文件是用db更新的,当你链接它时它的ip地址.所以你可以:

<Context>
  <Resource
    name="jdbc/MYDB"
    type="javax.sql.DataSource"
    auth="Container"
    username="user"
    password="password"
    driverClassName="com.mysql.jdbc.Driver"
    url="jdbc:mysql:db:3306/epcis?autoReconnect=true">
  </Resource>
</Context>

我使用的另一种技术是skydns和registrator,然后你在DNS srv记录中获得ip和port.

我不记得Tomcat但它应该可以访问变量.您确定Tomcat在使用它之前评估了url定义吗?

上一篇:java – 是否需要tomcat的server.xml的factory属性?


下一篇:java – 如何在JDBC数据源级别限制从Oracle返回的行数?