如何使用 Tomcat 和 IntelliJ IDEA 获取 context.xml

Jac*_*k J 5 java tomcat connection-pooling intellij-idea context.xml

我一直在学习连接池,并且通过使用 Tomcat 的 PoolProperties获得了一个工作。现在我想使用带有 Tomcat 和 IntelliJ 的 context.xml 文件来设置一个,但我无法让它工作。这是怎么做的?

4.0 Web Application 框架的新项目可以自动创建带有 web.xml 文件的 web/WEB-INF 目录,但是没有创建包含 context.xml 文件的 web/META-INF 目录。如果我自己通过工具窗口> 项目创建 web/META-INF/context.xml,并使用它来设置连接池,如下所示,该文件似乎被忽略。

这是我对可能发生的事情的猜测,尽管我确信这充满了错误:WAR 文件是一个打包目录,它以 Tomcat 理解的安排发送到 Tomcat。web/WEB-INF/web.xml 是一个必需的文件,出于多种原因需要它,其中之一是设置 servlet。web/META-INF/context.xml 是可选的,因此默认情况下,IntelliJ 不会创建它。当手动创建 web/META-INF/context.xml 时,它也必须包含在 WAR 文件中,否则 IntelliJ 不会将其发送到 Tomcat。

即使上一段是正确的,在尝试将它添加到 WAR 之后,我仍然没有让 Tomcat 使用 context.xml。也许我没有正确添加它。

上下文.xml

<?xml version="1.0" encoding="UTF-8" ?>
<Context>

    <Resource name="jdbc/sql_connection_03" auth="Container"
              driverClassName="com.mysql.jdbc.Driver"
              url="jdbc:mysql://localhost:3306/follow_db_01"
              username="root" password="pass"
              maxactive="100" maxIdle="30" maxWait="10000"
              logAbandoned="true" removeAbandoned="true"
              removeAbandonedTimeout="60" type="java.sql.DataSource"/>

</Context>
Run Code Online (Sandbox Code Playgroud)

索引.jsp

<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<sql:query var="rs" dataSource="jdbc/sql_connection_03">
    select ID, Description, PackageSize from products;
</sql:query>

<html>
  <head>
    <title>Index</title>
  </head>
  <body>

    <c:forEach var="row" items="${rs.rows}">
        ${row.ID}<br>
        ${row.Description}<br>
        ${row.PackageSize}<br>
    </c:forEach>

  </body>
</html>
Run Code Online (Sandbox Code Playgroud)

msT*_*Tam 1

我遇到了同样的问题,并将上下文查找添加到我的 java 代码中以使用 context.xml 中定义的资源完成了这项工作。

这是公认的解决方案:Tomcat 和 JDBC 连接池

仍然适用于 Tomcat 9.0.39