gpt4 book ai didi

java - 部署在 mochahost 共享服务器上时出现 NullPointerException 获取连接

转载 作者:行者123 更新时间:2023-11-29 07:04:41 25 4
gpt4 key购买 nike

我刚刚将在本地主机上运行良好的 Spring 应用程序 移动到 mochahost 上的共享网络托管服务器,我看到以下异常(截断)根本原因:

root cause

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'adDaoImpl': Injection of autowired dependencies failed; nested exception is java.lang.NullPointerException
org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:288)
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1074)
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:517)
org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
(truncated)

及以下:

root cause

java.lang.NullPointerException
com.adsense.connection.MySqlDBPooling.getConnection(MySqlDBPooling.java:28)
com.adsense.dao.impl.AdDaoImpl.setDataSource(AdDaoImpl.java:21)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
java.lang.reflect.Method.invoke(Method.java:597)
org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredMethodElement.inject(AutowiredAnnotationBeanPostProcessor.java:588)
(truncated)

AdDaoImpl.java

@Repository
public class AdDaoImpl implements AdDao{

Connection conn;

@Autowired
public void setDataSource(){
try{
conn = (new MySqlDBPooling()).getConnection();
}catch(SQLException e){
e.printStackTrace();
}
}

...
...
}

MySqlDBPooling.java

package com.adsense.connection;

import java.sql.Connection;
import java.sql.SQLException;
import javax.naming.*;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.sql.DataSource;

public class MySqlDBPooling implements ServletContextListener{

private static DataSource ds;

public MySqlDBPooling(){
}

public void contextInitialized(ServletContextEvent sce){
try{
Context envCtx = (Context)(new InitialContext()).lookup("java:comp/env");
ds = (DataSource)envCtx.lookup("jdbc/AdSenseDB");
System.out.println((new StringBuilder("MySqlDBPooling is set to ")).append(ds.toString()).toString());
}catch(NamingException e){
e.printStackTrace();
}
}

public Connection getConnection() throws SQLException{
return ds.getConnection(); // getting NullPointerException here
}

public void contextDestroyed(ServletContextEvent servletcontextevent){
}
}

上下文.xml

<?xml version="1.0" encoding="UTF-8"?>
<Context antiResourceLocking="false" privileged="true" version="5.0">
<Resource
name="jdbc/AdSenseDB"
auth="Container"
type="javax.sql.DataSource"
removeAbandoned="true"
removeAbandonedTimeout="30"
maxActive="300"
maxIdle="300"
maxWait="1000"
username="<username here>"
password="<password here>"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/adsense_adsense"/>
</Context>

网络.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>Adsense</display-name>
<listener>
<listener-class>com.adsense.connection.MySqlDBPooling</listener-class>
</listener>
<servlet>
<servlet-name>spring</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>spring</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.css</url-pattern>
<url-pattern>*.js</url-pattern>
<url-pattern>*.jpg</url-pattern>
<url-pattern>*.jpeg</url-pattern>
<url-pattern>*.png</url-pattern>
<url-pattern>*.gif</url-pattern>
<url-pattern>*.ico</url-pattern>
</servlet-mapping>
</web-app>

几点:

  1. 我已将我的 jar(包括 mysql-connector-java-5.1.10.jar)放在/WEB-INF/lib 中。在本地主机上,mysqlconnector 位于 tomcat 库中。但由于这是一个共享服务器,我无法访问 tomcat 库。 WEB-INF/lib 可能是 mysql 连接器的错误位置。

  2. WEB-INF/lib 可能是放置库的错误位置。在我在 Amazon Web 服务器上运行的其他应用程序(与此无关)中,我已将所有库放在 tomcat libs 文件夹中。

  3. 在 context.xml 中,我什至将 url 更改为 jdbc:mysql://domain.com:3306/adsense_adsense,即将 localhost 替换为实际域,但这没有帮助。

  4. 在 MySqlDBPooling.java 中,如果 ds 为 null,为什么它不早点抛出 NullPointerException

System.out.println((new StringBuilder("MySqlDBPooling is set to ")).append(ds.toString()).toString());

在服务器启动期间执行(MySqlDBPooling 类作为监听器添加到 web.xml 中)

感谢您的关注。

詹姆斯

编辑:

在我按照@JB Nizet 的建议(使用 Spring 获取数据源)将 MySqlDBPooling.java 更新为:

package com.adsense.connection;

import java.sql.Connection;
import java.sql.SQLException;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

import org.springframework.jdbc.datasource.DriverManagerDataSource;

public class MySqlDBPooling implements ServletContextListener{

private static DriverManagerDataSource ds;

public MySqlDBPooling(){
}

public void contextInitialized(ServletContextEvent sce){
try{
ds = new DriverManagerDataSource();
ds.setDriverClassName( "com.mysql.jdbc.Driver");
ds.setUrl( "jdbc:mysql://localhost:3306/adsense_adsense");
ds.setUsername( "USERNAME");
ds.setPassword( "PASSWORD");
System.out.println("Datasource is: "+ds.toString());
}catch(Exception e){
e.printStackTrace();
}
}

public Connection getConnection() throws SQLException{
return ds.getConnection();
}

public void contextDestroyed(ServletContextEvent servletcontextevent){
}
}

最佳答案

如果您在 context.xml 中声明了一个 DataSource,Tomcat 会尝试使用它自己的类加载器而不是 Web 应用程序的类加载器来实例化它。所以WEB-INF/lib中的driver jar不在其classpath中,无法加载driver。

您没有更快看到 NPE 的原因是 JNDI 查找可能因 NamingException 而失败。您应该在部署时在日志中看到此异常的堆栈跟踪。

由于您使用的是 Spring,因此您可以从 Spring(使用独立连接池)创建 DataSource,而不是让 Tomcat 创建它。参见 http://static.springsource.org/spring/docs/3.0.x/spring-framework-reference/htmlsingle/spring-framework-reference.html#jdbc-datasource

关于java - 部署在 mochahost 共享服务器上时出现 NullPointerException 获取连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8076697/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com