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 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)
<%@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)
我遇到了同样的问题,并将上下文查找添加到我的 java 代码中以使用 context.xml 中定义的资源完成了这项工作。
这是公认的解决方案:Tomcat 和 JDBC 连接池
仍然适用于 Tomcat 9.0.39
| 归档时间: |
|
| 查看次数: |
1084 次 |
| 最近记录: |