【问题标题】:ClassNotFoundException: com.mysql.jdbc.jdbc2.optional.MysqlDataSourceClassNotFoundException:com.mysql.jdbc.jdbc2.optional.MysqlDataSource
【发布时间】:2015-03-03 07:59:20
【问题描述】:

我在我的项目中使用 Hikari 库进行 MySQL 连接。当我尝试运行该程序时,我得到一个 ClassNotFoundException: com.mysql.jdbc.jdbc2.optional.MysqlDataSource 错误。我想我必须在我的项目中包含 mysql-connector 库。

这是我的 pom.xml

    <dependencies>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.34</version>
        </dependency>
        <dependency>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP-java6</artifactId>
            <version>2.0.1</version>
        </dependency>
        <dependency>
            <groupId>org.javassist</groupId>
            <artifactId>javassist</artifactId>
            <version>3.18.1-GA</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-simple</artifactId>
            <version>1.7.5</version>
        </dependency>
        <dependency>
            <groupId>io.netty</groupId>
            <artifactId>netty-all</artifactId>
            <version>4.1.0.Beta3</version>
            <scope>compile</scope>
        </dependency>
    </dependencies>

    <build>
        <finalName>GridControl</finalName>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
        </resources>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>2.4</version>
                <configuration>
                    <archive>
                        <manifestEntries>
                            <Main-Class>net.thegridmc.control.GridControl</Main-Class>
                        </manifestEntries>
                    </archive>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>2.3</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <minimizeJar>true</minimizeJar>
                            <createDependencyReducedPom>false</createDependencyReducedPom>
                            <artifactSet>
                                <includes>
                                    <include>mysql:*</include>
                                    <include>org.slf4j:*</include>
                                    <include>com.zaxxer:*</include>
                                    <include>org.javassist:javassist</include>
                                    <include>io.netty:netty-all</include>
                                </includes>
                            </artifactSet>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

jar 构建成功,但错误仍然存​​在。非常感谢任何帮助。谢谢。

【问题讨论】:

  • 尝试在你下载的jar中查找需要的文件
  • 你用什么做应用服务器?也许您需要设置一个环境变量来定义库的路径。

标签: java mysql maven jdbc


【解决方案1】:

试试com.mysql.cj.jdbc.MysqlDataSource。它适用于

mysql-connector-java 6.0.4

【讨论】:

    【解决方案2】:

    所以我在升级Spring 版本后遇到了同样的问题。这个问题已经有了正确的答案,但缺乏细节。要连接到数据源(例如:MySQL),您需要有适当的驱动程序。以前Driver 曾经位于com.mysql.jdbc.Driver,但现在它位于com.mysql.cj.jdbc.Driver。所以你需要更新你的数据源定义。

    <bean id="dataSource" class="com.mysql.cj.jdbc.MysqlDataSource"
            destroy-method="close">
        <property name="url" value="${jdbc.url}" /> <!-- Loaded from application.properties file -->
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        <property name="maxIdle" value="1" />
    </bean>
    

    光示例:

    <bean id="hikariConfig" class="com.zaxxer.hikari.HikariConfig">
        <property name="poolName" value="springHikariCP" />
        <property name="connectionTestQuery" value="SET NAMES utf8mb4" />
        <property name="dataSourceClassName" value="com.mysql.cj.jdbc.MysqlDataSource" />
        <property name="dataSourceProperties">
            <props>
                <prop key="url">${jdbc.url}</prop> <!-- Loaded from application.properties file -->
                <prop key="user">${jdbc.username}</prop>
                <prop key="password">${jdbc.password}</prop>
            </props>
        </property>
    </bean>
    <bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource"
        destroy-method="close">
        <constructor-arg ref="hikariConfig" />
    </bean>
    

    【讨论】:

      【解决方案3】:

      HikariCP 表示未使用驱动配置,您应该为 MySQL 定义 jdbcUrl:

      MySQL 连接器/J com.mysql.jdbc.jdbc2.optional.MysqlDataSource

      已知 MySQL 数据源在网络超时支持方面存在问题。请改用 jdbcUrl 配置。

      【讨论】:

        【解决方案4】:

        我设法通过将“minimizeJar”设置为 false 来解决这个问题。我对maven不太熟悉,所以我不知道这是如何解决的,但确实如此。

        【讨论】: