Hibernate Open Session in View: Pitfalls and Alternatives
Open Sesi in View, walaupun nampak mudah, mengalami beberapa kelemahan yang memerlukan berhati-hati dalam penggunaannya.
Isu dengan Sesi Terbuka dalam Lihat
Walaupun pendekatan itu boleh mengurangkan titik kesakitan dalam senario JVM terpencil, ia datang pada kos:
-
Mod autokomit dalam pemaparan UI: Selepas perkhidmatan -penyelesaian transaksi lapisan dan penutupan Sesi, pemaparan UI seterusnya mencetuskan autokomit untuk setiap penyata, meningkatkan beban pangkalan data akibat I/O yang berlebihan.
-
Kehilangan pemisahan kebimbangan: Penjanaan penyata merangkumi kedua-dua lapisan perkhidmatan dan UI, merumitkan ujian integrasi dan pengasingan logik perniagaan.
-
Potensi masalah pertanyaan N 1: Navigasi UI terhad kepada merentasi persatuan, yang boleh memburukkan lagi isu prestasi apabila persatuan tidak diambil dengan penuh semangat.
-
Peningkatan masa pajakan sambungan: Sambungan pangkalan data boleh kekal terbuka sepanjang pemaparan UI, yang membawa kepada kesesakan dan pemprosesan transaksi terhad.
Strategi Alternatif
Untuk mengelakkan perangkap Open Session in View, pertimbangkan alternatif berikut:
-
Eager fetching: Ambil semua perkaitan yang diperlukan dalam skop EntityManager, memastikan pengamulaan malas tidak dicetuskan semasa pemaparan UI.
-
Penyesuaian mod Ambil: Gunakan Anotasi @BatchSize dan FetchMode.SUBSELECT Hibernate dengan bijak untuk mengoptimumkan pengambilan persatuan tanpa memberi kesan kepada semua senario perniagaan.
-
Pertanyaan lapisan akses data: Cipta pertanyaan yang disesuaikan yang menangani keperluan pengambilan data khusus bagi sesuatu tertentu bekas penggunaan.
But Musim Bunga Konfigurasi
Dalam But Spring, Open Session in View didayakan secara lalai. Untuk melumpuhkannya, tetapkan sifat berikut dalam konfigurasi application.properties:
spring.jpa.open-in-view=false
Ini akan memaksa pengendalian LazyInitializationExceptions yang betul, mengelakkan akibat yang tidak diingini yang dikaitkan dengan Open Session in View.
Atas ialah kandungan terperinci Adakah Sesi Terbuka dalam Lihat Pilihan yang Tepat? Perangkap dan Alternatif yang Lebih Baik. 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