Rumah >Java >javaTutorial >Bagaimana untuk Mencegah Tamat Masa Sambungan Pangkalan Data dalam Aplikasi Spring Boot Menggunakan JPA dan Hibernate?

Bagaimana untuk Mencegah Tamat Masa Sambungan Pangkalan Data dalam Aplikasi Spring Boot Menggunakan JPA dan Hibernate?

Patricia Arquette
Patricia Arquetteasal
2024-10-25 05:38:29460semak imbas

How to Prevent Database Connection Timeouts in Spring Boot Applications Using JPA and Hibernate?

Sambungan ke Pangkalan Data Hilang Selepas Selang Masa Tertentu: Spring Boot, JPA, Hibernate

Dalam aplikasi Spring Boot menggunakan JPA dan Hibernate dengan MySQL, pengguna mungkin menghadapi ralat yang menunjukkan bahawa sambungan ke pangkalan data telah tamat masa. Untuk menyelesaikan isu ini, mari kita terokai pendekatan yang disyorkan dan tidak digalakkan:

Pendekatan Tidak Digalakkan: Mendayakan Auto-Sambung Semula

Walaupun pantas dan mudah, mendayakan auto-sambung semula dalam JDBC URL tidak disyorkan. Ia boleh menimbulkan isu semasa sambungan aktif, terutamanya apabila transaksi terganggu.

Pendekatan Disyorkan: Pengesahan Sambungan

Untuk menangani isu ini dengan berkesan, adalah penting untuk mendayakan pengesahan sambungan sepanjang sepanjang hayat permohonan itu. Ini melibatkan konfigurasi berbilang sifat:

  • Bilangan Maksimum Sambungan Aktif: spring.datasource.max-active (mis., 10)
  • Bilangan Sambungan Permulaan: spring.datasource.initial-size (cth., 5)
  • Bilangan Minimum dan Maksimum Sambungan Terbiar: spring.datasource.max-idle dan spring.datasource. melahu min (cth., 5 dan 1)
  • Pengesahan Semasa Melahu dan Semasa Meminjam: spring.datasource.test-while-idle dan spring.datasource.test-on-borrow (kedua-duanya ditetapkan kepada benar)
  • Pertanyaan Pengesahan: spring.datasource.validation-query (cth., "PILIH 1")
  • Masa Antara Pengesahan Berjalan: spring.datasource.time-between-eviction-runs-millis (cth., 5000 milisaat)
  • Masa Terbiar Minimum untuk Pengusiran: spring.datasource.min-evictable-idle-time- millis (cth., 60000 milisaat)

Konfigurasi ini memastikan sambungan diuji secara kerap untuk kesahihan dan sambungan melahu dialih keluar daripada kolam jika ia kekal tidak digunakan untuk tempoh tertentu.

Kemas Kini Spring Boot 2.x:

Perhatikan bahawa Spring Boot 2.x bertukar kepada HikariCP sebagai kumpulan sambungan lalai dan bukannya Tomcat JDBC. Akibatnya, sifat konfigurasi untuk pengesahan sambungan mungkin berbeza sedikit.

Atas ialah kandungan terperinci Bagaimana untuk Mencegah Tamat Masa Sambungan Pangkalan Data dalam Aplikasi Spring Boot Menggunakan JPA dan Hibernate?. 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