Ubuntu,Java,找不到适合的驱动程序jdbc:postgresql

时间:2018-12-27 01:39:01

标签: java sql postgresql jsp ubuntu

我已经创建了一个JSP服务器(tomcat)并将其链接到我的Eclipse IDE。我还创建了一个PostgreSQL服务器,并试图弄清楚如何通过我的JSP服务器连接到它。

这是我的JSP文件的样子:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
    <%@ page import="helloWorldJSP.Test" %>
    <%@ page import="helloWorldJSP.SQLTest" %>
</head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
    //Test testThing = new Test();  
    //out.println( testThing.caps("thing") );
    SQLTest test = new SQLTest();
    System.out.println("FINISH");
%>


</body>
</html>

我已经对其进行了测试,并且可以正常工作,所以我认为错误不在此页面内。

这是我的SQLTest类的代码:

package helloWorldJSP;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;

public class SQLTest 
{
    public SQLTest() 
    {
        Connection conn = null;
        System.out.println("STARTING");

        try 
        {

            String url = "jdbc:postgresql://localhost:5432/deama_db";
            String user = "deama1295";
            String password = "1295";

            conn = DriverManager.getConnection(url, user, password);
            if (conn != null) 
            {
                System.out.println("Connected to the database postgres");
            }
        }
        catch (SQLException ex) 
        {
            System.out.println("An error occurred. Maybe user/password is invalid");
            ex.printStackTrace();
        }
    }
}

在我的tomcat服务器lib文件夹中,我正在寻找JDBC驱动程序,并且该驱动程序已经存在。 我正在从virtualBox虚拟机运行Ubuntu-18.10-desktop-amd64。

我尝试将数据库和用户名更改为“ postgres”(我相信默认值?),但这并没有改变我的错误(我很确定我将postgres的密码设置为1295)。

这是完整的错误消息:

java.sql.SQLException: No suitable driver found for jdbc:postgresql://localhost/deama_db
    at java.sql.DriverManager.getConnection(DriverManager.java:689)
    at java.sql.DriverManager.getConnection(DriverManager.java:208)
    at helloWorldJSP.SQLTest.<init>(SQLTest.java:26)
    at org.apache.jsp.NewFile_jsp._jspService(NewFile_jsp.java:127)
    at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476)
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
    at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:800)
    at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
    at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:806)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498)
    at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Thread.java:748)

2 个答案:

答案 0 :(得分:0)

您可能缺少对PostgreSQL JDBC驱动程序的引用。此might be a relevant answer(对于Android操作系统)。

由于使用的是ASP.NET,因此可能需要安装Postgres via this nuget

您最有可能需要将Postgres添加到您的Java应用程序中,引用:

您需要按照Mvnrepository中的说明在项目中添加PostgreSQL JDBC驱动程序。

成绩

// http://mvnrepository.com/artifact/postgresql/postgresql
compile group: 'postgresql', name: 'postgresql', version: '9.0-801.jdbc4'

Maven

<dependency>
    <groupId>postgresql</groupId>
    <artifactId>postgresql</artifactId>
    <version>9.0-801.jdbc4</version>
</dependency>

您还可以download JAR 并手动导入到项目中。

答案 1 :(得分:0)

根据JNDI Datasources上的Tomcat 8文档,使用DriverManager加载驱动程序的默认行为是从Apache-Tomcat-Home/lib文件夹中读取驱动程序。否则,您将必须明确注册驱动程序。它基本上与Tomcat的类加载机制有关。以下是文档摘录:

  

Apache Tomcat随附的JRE内存泄漏预防侦听器通过在Tomcat启动期间触发驱动程序扫描来解决此问题。默认情况下启用。这意味着将仅扫描侦听器可见的库,例如$ CATALINA_BASE / lib中的库,以查找数据库驱动程序。如果要考虑禁用此功能,请注意,扫描将由使用JDBC的第一个Web应用程序触发,从而导致在重新加载此Web应用程序以及其他依赖此功能的Web应用程序时失败。

     

因此,在其WEB-INF / lib目录中具有数据库驱动程序的Web应用程序不能依赖服务提供程序机制,而应显式注册驱动程序。   此行为应适用于更新版本的Tomcat。

此处的关键是使用DriverManager查找数据库驱动程序时的JRE Memory Leak Prevention Listener行为。根据文档,此侦听器:

  

为Java Runtime环境使用上下文类加载器加载单例的已知位置提供了解决方法,因为如果Web应用程序类加载器当时恰好是上下文类加载器,则这将导致内存泄漏。解决方法是在此侦听器启动时初始化这些单例,因为Tomcat的公共类加载器当时是上下文类加载器。

但是在您的情况下,我能够重现该错误,Web应用程序类加载器不同于上下文类加载器,因此找不到驱动程序。因此,解决方案是将侦听器配置为禁用DriverManager保护-它设置为true的默认值。为此,您可以将driverManagerProtection文件中的false属性值设置为Apache-Tomcat-Home/conf/server.xml

<Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" driverManagerProtection="false"/>

也就是说,我不认为DriverManager是在Web服务器中实例化数据库连接的正确方法。数据库连接很昂贵。我建议使用DataSource,它可以池化连接并因此提高性能。有关示例,请参见提供的文档链接。

但是,我确实相信每种技术都有它的地位。所以...我将由您自己决定适合您的情况。但至少您有答案。