我尝试在tomcat 7.0.52
上运行项目,并通过context.xml
文件初始化为DB。
但它引发了一堆例外,我无法弄清楚那里有什么问题。
这是控制台输出:
java.sql.SQLException: com.mysql.jdbc.Driver
at org.apache.tomcat.jdbc.pool.PooledConnection.connectUsingDriver(PooledConnection.java:254)
at org.apache.tomcat.jdbc.pool.PooledConnection.connect(PooledConnection.java:182)
at org.apache.tomcat.jdbc.pool.ConnectionPool.createConnection(ConnectionPool.java:701)
at org.apache.tomcat.jdbc.pool.ConnectionPool.borrowConnection(ConnectionPool.java:635)
at org.apache.tomcat.jdbc.pool.ConnectionPool.init(ConnectionPool.java:486)
at org.apache.tomcat.jdbc.pool.ConnectionPool.<init>(ConnectionPool.java:144)
at org.apache.tomcat.jdbc.pool.DataSourceProxy.pCreatePool(DataSourceProxy.java:116)
at org.apache.tomcat.jdbc.pool.DataSourceProxy.createPool(DataSourceProxy.java:103)
at org.apache.tomcat.jdbc.pool.DataSourceFactory.createDataSource(DataSourceFactory.java:554)
at org.apache.tomcat.jdbc.pool.DataSourceFactory.getObjectInstance(DataSourceFactory.java:242)
at org.apache.naming.factory.ResourceFactory.getObjectInstance(ResourceFactory.java:141)
at javax.naming.spi.NamingManager.getObjectInstance(NamingManager.java:321)
这是完整的stack trace。
web.xml 的摘录:
<resource-ref>
<description>Travel Agency Datasource</description>
<res-ref-name>jdbc/onlinedb</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
context.xml中:
<Context>
<Resource name="jdbc/onlinedb"
type="javax.sql.DataSource"
factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"
maxActive="20" maxIdle="10"
maxWait="-1"
username="root"
password="secret"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/travelagency?characterEncoding=utf8"/>
</Context>
ConnectionManager 类:
public class ConnectionManager {
private static Logger log = Logger.getLogger(ConnectionManager.class);
public static Connection getConnection() throws SQLException {
Connection con = null;
try {
Context initContext = new InitialContext();
Context envContext = (Context) initContext.lookup("java:/comp/env");
DataSource datasource = (DataSource) envContext.lookup("jdbc/onlinedb");
con = datasource.getConnection();
} catch (NamingException e) {
log.error(e);
}
return con;
}
}
mysql-connector-java-5.1.27-bin.jar
已添加到cp:
我尝试更改context.xml文件的内容:
<resource-env-ref>
<description>Travel Agency Datasource</description>
<resource-env-ref-name>jdbc/onlinedb</resource-env-ref-name>
<resource-env-ref-type>javax.sql.DataSource</resource-env-ref-type>
</resource-env-ref>
但它一直都在失败。
如何解决这个问题?
答案 0 :(得分:11)
您必须将MySQL jdbc驱动程序添加到类路径中。
将MySQL二进制jar放到 tomcat lib 文件夹中,或将其添加到我们的应用程序 WEB-INF / lib 文件夹中。
您可以找到二进制jar(相应地更改版本):https://mvnrepository.com/artifact/mysql/mysql-connector-java/5.1.27
答案 1 :(得分:5)
当您遇到这样的异常时,最有用的信息通常位于堆栈跟踪的底部:
Caused by: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
...
at org.apache.tomcat.jdbc.pool.PooledConnection.connectUsingDriver(PooledConnection.java:246)
问题是Tomcat找不到com.mysql.jdbc.Driver
。这通常是由包含MySQL驱动程序的JAR引起的,而不是Tomcat期望找到它的地方(即webapps/<yourwebapp>/WEB-INF/lib
目录中)。
答案 2 :(得分:2)
在调整完全工作的context.xml设置后,我也处理了这个异常。我不想在context.xml中使用环境细节,所以我把它们拿出来看到了这个错误。我意识到我必须在基于System Property JVM -D args的代码中完全创建这个数据源资源。
仅删除了user / pwd / host的原始错误: org.apache.tomcat.jdbc.pool.ConnectionPool init 严重:无法创建池的初始连接。
删除了context.xml的全部内容并试试这个: 在使用第一个连接之前的某个时间初始化应用服务器启动数据源对象。如果使用Spring,那么在@Bean Datasource构造函数中的@Configuration bean中可以做到这一点。
要使用的包:org.apache.tomcat.jdbc.pool。*
PoolProperties p = new PoolProperties();
p.setUrl(jdbcUrl);
p.setDriverClassName(driverClass);
p.setUsername(user);
p.setPassword(pwd);
p.setJmxEnabled(true);
p.setTestWhileIdle(false);
p.setTestOnBorrow(true);
p.setValidationQuery("SELECT 1");
p.setTestOnReturn(false);
p.setValidationInterval(30000);
p.setValidationQueryTimeout(100);
p.setTimeBetweenEvictionRunsMillis(30000);
p.setMaxActive(100);
p.setInitialSize(5);
p.setMaxWait(10000);
p.setRemoveAbandonedTimeout(60);
p.setMinEvictableIdleTimeMillis(30000);
p.setMinIdle(5);
p.setLogAbandoned(true);
p.setRemoveAbandoned(true);
p.setJdbcInterceptors(
"org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;"+
"org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer");
org.apache.tomcat.jdbc.pool.DataSource ds = new org.apache.tomcat.jdbc.pool.DataSource();
ds.setPoolProperties(p);
return ds;
答案 3 :(得分:1)
我使用sprint-boot(2.1.1),而mysql版本是8.0.13。我在pom中添加依赖项,解决了我的问题。
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.13</version>
</dependency>
MySQL Connector / J»8.0.13链接:https://mvnrepository.com/artifact/mysql/mysql-connector-java/8.0.13
MySQL Connector / J»所有版本链接:
https://mvnrepository.com/artifact/mysql/mysql-connector-java