SpringBoot가 Druid를 통합하여 MySQL8.0.11에 연결하는 방법

王林
풀어 주다: 2023-05-29 10:49:06
앞으로
1379명이 탐색했습니다.

1. 종속성 구성

종속성 관리를 위해 maven 또는 gradle을 사용할 수 있습니다.
MySQL 커넥터/J 버전 선택:

SpringBoot가 Druid를 통합하여 MySQL8.0.11에 연결하는 방법

참고: MySQL5.X 시리즈인 경우 8.0과 호환됩니다. X 드라이버 문제가 발생했습니다. 주의해주세요!

1.1MySQL 커넥터/J 종속성 구성 maven

<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.11</version>
</dependency>
로그인 후 복사

gradle

// https://mvnrepository.com/artifact/mysql/mysql-connector-java
compile group: "mysql", name: "mysql-connector-java", version: "8.0.11"
로그인 후 복사

1.2Druid 종속성 구성

maven

<!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.10</version>
</dependency>
로그인 후 복사

####gradle

// https://mvnrepository.com/artifact/com.alibaba/druid
compile group: "com.alibaba", name: "druid", version: "1.1.10"
로그인 후 복사

2 구성 DataSource

여기에서는 Java Config를 사용합니다. YAML 구성을 사용했을 때 코드 프롬프트가 불완전하여 오류 발생 가능성이 크게 높아졌으므로 Java Config를 사용하는 것이 좋습니다.

2.1 구성 클래스 생성

@Configuration
public class Config {
    @Bean
    public DruidDataSource druidDataSource() {
        //Druid 数据源配置
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://127.0.0.1:3306/work?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true");
        dataSource.setUsername("webuser");
        dataSource.setPassword("123456");
        //初始连接数(默认值0)
        dataSource.setInitialSize(8);
        //最小连接数(默认值0)
        dataSource.setMinIdle(8);
        //最大连接数(默认值8,注意"maxIdle"这个属性已经弃用)
        dataSource.setMaxActive(32);
        return dataSource;
    }
}
로그인 후 복사

2.2 Notes

코드에 몇 가지 주석이 기록되어 있습니다. 여기에 두 개의 메모가 있습니다.
하나는 DriverClassName
8.0.11 드라이버(버전 8부터 시작해야 함), 원래 드라이버는 폐기되었습니다. 소스 코드를 직접 보면 찾을 수 있습니다.
com.mysql.jdbc.Driver

Loading 클래스 `com.mysql.jdbc.Driver"에는 두 문장이 있습니다. 이는 더 이상 사용되지 않습니다. 새 드라이버 클래스는 `com.mysql.cj.jdbc.Driver"입니다.
The 드라이버는 SPI를 통해 자동으로 등록되며 드라이버 클래스를 수동으로 로드하는 것은 일반적으로 필요하지 않습니다.

클래스 "com.mysql.jdbc.Driver"를 로드하는 것을 의미합니다. 이는 더 이상 사용되지 않습니다. 새 드라이버 클래스는 `com.mysql.cj.jdbc.Driver"이므로 "setDriverClassName" 속성 설정에 주의하세요. 또 다른 참고 사항은 URL 설정입니다. 주의해야 할 4가지 매개 변수가 있습니다

  • characterEncoding=utf8 ( 문자 인코딩)

  • useSSL=false (버전 8부터 추가만 하면 되는 것으로 확인되었습니다. 5에서는 필요하지 않습니다. 데이터베이스에 연결할 때 이 매개변수를 추가하세요. 이 문제는 Druid 연결 풀을 사용할 때만 발생하는 것 같습니다.

  • allowPublicKeyRetrieval=true (루트 계정으로 로그인하면 문제가 없으나, 사용 시 공개 키 검색 메시지가 표시됩니다. 일반계정) 오류)


  • 자세한 구성은 Druid 프로젝트의 위키를 참고하셔서 필요에 맞게 구성해주세요

위 내용은 SpringBoot가 Druid를 통합하여 MySQL8.0.11에 연결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!