JDBC error when moving JAR from $ HOME / jre / lib / ext to Gradle

My team has our com.mysql.jdbc.Driver jar application in the $ JAVA_HOME / jre / lib / ext / folder, but I'm trying to remove this JDK dependency to create a more repeatable build using Gradle.

I added a driver to my build.gradle, which you can see at the top of my dependencies:

dependencies {
        compile group: 'mysql', name: 'mysql-connector-java', version: '5.1.+'
        compile group: 'com.notnoop.apns', name: 'apns', version: '1.0.0.Beta6'
        compile group: 'org.slf4j', name: 'slf4j-api', version: '1.7.21'
        compile group: 'com.google.code.gson', name: 'gson', version: '1.7.2'
        compile group: 'net.sf.jazzy', name: 'jazzy', version: '0.5.2-rtext-1.4.1'
        compile group: 'org.apache.lucene', name: 'com.springsource.org.apache.lucene.search.spell', version: '2.4.1'
        compile group: 'com.rabbitmq', name: 'com.springsource.com.rabbitmq.client', version: '1.8.1'
        compile group: 'com.sun.xml', name: 'com.springsource.com.sun.xml.bind', version: '2.2.0'
        compile group: 'com.sun.xml.rpc', name: 'jaxrpc-impl', version: '1.1.3_01'
        compile group: 'com.rabbitmq', name: 'amqp-client', version: '3.6.5'
        testCompile group: 'junit', name: 'junit', version: '4.11'
        compile group: 'com.mashape.unirest', name: 'unirest-java', version: '1.3.1'
        compile fileTree(dir: 'local_lib', include: '*.jar')
}

After removing the jar from $ JAVA_HOME / jre / lib / ext / and putting it in gradle, I get this error in the Catalina logs after trying to access the database:

database.BaseDbao.getConnection - We could not create any connection.
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot load JDBC driver class 'com.mysql.jdbc.Driver'
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1136)
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:880)
    at database.BaseDbao.getConnection(BaseDbao.java:116)
    at database.UserDbao.getAuthorizedResultBean(UserDbao.java:357)
    at database.Dbao.getAuthorizedResultBean(Dbao.java:3635)
    at AuthServlet.doPost(AuthServlet.java:71)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at servlets.filters.servletContextFilter.doFilter(servletContextFilter.java:11)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
    at java.lang.Thread.run(Thread.java:745)
Caused by: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:264)
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1130)
    ... 22 more
Dbao.getAuthorizationResultBean() Error - Cannot load JDBC driver class 'com.mysql.jdbc.Driver'
LoginFailed for :suburbantest:because ::10.0.0.22

Any insight would be much appreciated!

+4
source share
1 answer

Tomcat , .

Tomcat . -, , , : JDK (Bootstrap), Tomcat (System) classloader ( , ).

$JAVA_HOME/jre/lib/ext/, JDK classloader. tomcat/lib, Tomcat. gradle, .

Tomcat, JDK Tomcat.

( Tomcat? , ?)

+5

Source: https://habr.com/ru/post/1673159/


All Articles