Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menyelesaikan Gangguan Sambungan Pangkalan Data JPA/Hibernate Spring Boot?

Bagaimana untuk Menyelesaikan Gangguan Sambungan Pangkalan Data JPA/Hibernate Spring Boot?

Patricia Arquette
Patricia Arquetteasal
2024-12-09 18:33:15702semak imbas

How to Resolve Spring Boot JPA/Hibernate Database Connection Interruptions?

Menyelesaikan Gangguan Sambungan Pangkalan Data dalam Spring Boot dengan jpa-hibernate

Mesej ralat menunjukkan bahawa sambungan antara aplikasi Spring Boot anda dan pangkalan data MySQL telah ditamatkan kerana ketidakaktifan melebihi tamat masa menunggu yang dikonfigurasikan pelayan. Untuk menangani isu ini, terdapat beberapa pendekatan yang disyorkan:

1. Mendayakan AutoSambung Semula:

Penyelesaian segera adalah untuk mendayakan penyambungan semula automatik dalam URL JDBC:

spring.datasource.url = jdbc:mysql://localhost:3306/test?autoReconnect=true

Walau bagaimanapun, kaedah ini tidak disyorkan kerana ia boleh membawa kepada tingkah laku yang tidak dijangka semasa urus niaga aktif.

2. Pengesahan Sambungan:

Pendekatan yang lebih berkesan ialah mendayakan pengesahan sambungan sepanjang hayat aplikasi anda. Konfigurasikan sifat berikut:

  • Sambungan aktif maksimum:

    spring.datasource.max-active=10
  • Sambungan awal:

    spring.datasource.initial-size=5
  • Sambungan melahu had:

    spring.datasource.max-idle=5
    spring.datasource.min-idle=1
  • Pertanyaan pengesahan dan pemasaan:

    spring.datasource.test-while-idle=true
    spring.datasource.test-on-borrow=true
    spring.datasource.validation-query=SELECT 1
    spring.datasource.time-between-eviction-runs-millis=5000
    spring.datasource.min-evictable-idle-time-millis=60000

Konfigurasi ini memastikan sambungan melahu disahkan secara kerap dan sambungan terputus dikeluarkan dari kolam.

3. Kolam Sambungan HikariCP:

But Musim Bunga 2.x lalai menggunakan HikariCP sebagai kumpulan sambungan. HikariCP menyediakan pengesahan sambungan automatik, jadi sifat pertanyaan pengesahan boleh diabaikan.

Nota: Walaupun menggunakan pertanyaan pengesahan tidak digalakkan, HikariCP mempunyai kaedah pengesahan sambungannya sendiri, yang lebih cekap.

Atas ialah kandungan terperinci Bagaimana untuk Menyelesaikan Gangguan Sambungan Pangkalan Data JPA/Hibernate Spring Boot?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn