Sebagai pengarang yang paling laris, saya menjemput anda untuk menerokai buku saya di Amazon. Jangan lupa ikuti saya di Medium dan tunjukkan sokongan anda. terima kasih! Sokongan anda bermakna dunia!
Sebagai pembangun Java dengan pengalaman bertahun-tahun mengoptimumkan aplikasi, saya telah menghadapi pelbagai cabaran prestasi. Hari ini, saya akan berkongsi enam teknik hebat untuk menala aplikasi JVM yang telah memberikan hasil secara konsisten.
Profil ialah asas kepada sebarang usaha pengoptimuman prestasi. Adalah penting untuk sentiasa menganalisis tingkah laku aplikasi anda di bawah keadaan dunia sebenar. Alat seperti JProfiler dan VisualVM memberikan cerapan yang tidak ternilai tentang masa pelaksanaan kaedah, penggunaan memori dan tingkah laku benang.
Saya pernah mengusahakan sistem yang mengalami kelembapan yang tidak dapat dijelaskan semasa waktu puncak. Dengan memprofilkan aplikasi, kami menemui kaedah yang kelihatan tidak berbahaya yang dipanggil beribu-ribu kali sesaat. Kaedah ini melakukan penggabungan rentetan yang tidak perlu, menyebabkan penciptaan objek yang berlebihan dan pengumpulan sampah. Selepas mengoptimumkan kaedah tunggal ini, masa tindak balas aplikasi kami bertambah baik sebanyak 30%.
Untuk memulakan pemprofilan, lampirkan JProfiler pada aplikasi anda yang sedang berjalan:
java -agentpath:/path/to/libjprofilerti.so=port=8849 -jar myapp.jar
Setelah disambungkan, anda boleh menganalisis penggunaan CPU, peruntukan memori dan juga prestasi pertanyaan SQL. Fokus pada kaedah panas - yang menggunakan paling banyak masa CPU atau memperuntukkan paling banyak memori.
Penalaan pengumpulan sampah (GC) ialah satu lagi aspek kritikal pengoptimuman prestasi Java. Pilihan pemungut sampah dan konfigurasinya boleh memberi kesan ketara kepada prestasi aplikasi dan tindak balas.
Untuk kebanyakan aplikasi moden, saya cadangkan bermula dengan pengumpul sampah G1. Ia direka bentuk untuk memberikan keseimbangan yang baik antara pemprosesan dan masa jeda, terutamanya untuk aplikasi dengan timbunan besar.
Untuk mendayakan G1GC dan menetapkan sasaran untuk masa jeda maksimum:
java -XX:+UseG1GC -XX:MaxGCPauseMillis=200 -jar myapp.jar
Namun, jangan berhenti hanya dengan mendayakan G1GC. Pantau log GC anda untuk memahami tingkah laku pengumpul:
java -XX:+UseG1GC -Xlog:gc*:file=gc.log -jar myapp.jar
Analisis log ini untuk mengenal pasti corak dan laraskan parameter GC anda dengan sewajarnya. Contohnya, jika anda sering melihat jeda GC penuh, anda mungkin perlu meningkatkan saiz timbunan anda atau melaraskan saiz rantau G1.
Untuk aplikasi dengan keperluan kependaman yang ketat, pertimbangkan untuk menggunakan ZGC atau Shenandoah. Pengumpul ini menyasarkan untuk mengekalkan jeda GC di bawah 10ms, walaupun untuk timbunan besar.
Penyusun JIT (Just-In-Time) ialah sekutu yang berkuasa dalam mencapai prestasi optimum. Ia menganalisis kod anda pada masa jalan dan menggunakan pengoptimuman yang canggih. Walau bagaimanapun, untuk memanfaatkan sepenuhnya JIT, adalah penting untuk memahami cara ia berfungsi.
Kaedah yang kerap dilaksanakan atau mengandungi gelung adalah calon utama untuk kompilasi JIT. Anda boleh membantu JIT dengan menstrukturkan kod anda untuk menjadikan laluan panas ini jelas. Contohnya, lebih suka gelung dengan keadaan keluar yang boleh diramal berbanding logik cawangan yang kompleks.
Untuk melihat kaedah yang sedang disusun, dayakan pengelogan JIT:
java -agentpath:/path/to/libjprofilerti.so=port=8849 -jar myapp.jar
Jika anda mendapati kaedah penting tidak sedang disusun, pertimbangkan untuk menggunakan bendera JVM untuk memaksa penyusunan:
java -XX:+UseG1GC -XX:MaxGCPauseMillis=200 -jar myapp.jar
Ini mengurangkan ambang seruan untuk kompilasi, yang berpotensi meningkatkan prestasi permulaan.
Memilih struktur data yang betul boleh membuat perbezaan besar dalam prestasi aplikasi. Koleksi standard Java adalah serba boleh, tetapi perpustakaan khusus boleh menawarkan peningkatan prestasi yang ketara untuk kes penggunaan tertentu.
Saya telah mencapai kejayaan besar dengan Eclipse Collections, terutamanya untuk aplikasi yang berurusan dengan set data yang besar. Sebagai contoh, menggantikan ArrayList standard dengan Eclipse IntArrayList boleh mengurangkan penggunaan memori dan meningkatkan kelajuan lelaran:
java -XX:+UseG1GC -Xlog:gc*:file=gc.log -jar myapp.jar
Untuk aplikasi dengan model domain yang kompleks, pertimbangkan untuk menggunakan koleksi khusus yang sepadan dengan corak akses data anda. Jika anda kerap perlu mencari objek dengan berbilang atribut, peta berbilang kunci mungkin lebih cekap daripada HashMaps bersarang.
Permulaan malas dan caching ialah teknik yang berkuasa untuk meningkatkan kedua-dua masa permulaan dan prestasi masa jalan. Dengan menangguhkan penciptaan objek sehingga perlu, anda boleh mengurangkan penggunaan memori dan meningkatkan masa permulaan.
Berikut ialah contoh mudah pemula malas:
java -XX:+PrintCompilation -jar myapp.jar
Corak penguncian yang disemak dua kali ini memastikan sumber yang mahal hanya dicipta apabila pertama kali diperlukan.
Untuk caching, saya dapati Kafein adalah perpustakaan yang sangat baik. Ia menyediakan penyelesaian caching berprestasi tinggi dan hampir optimum dengan konfigurasi minimum:
java -XX:CompileThreshold=1000 -jar myapp.jar
Cache ini akan menyimpan sehingga 10,000 entri, tamat tempohnya selepas 5 minit dan menyegarkannya secara automatik selepas 1 minit.
Mengoptimumkan operasi I/O adalah penting untuk aplikasi yang berurusan dengan sejumlah besar data atau komunikasi rangkaian yang kerap. I/O tanpa sekatan boleh meningkatkan daya pemprosesan dengan ketara dengan membenarkan satu utas mengendalikan berbilang sambungan.
Java NIO menyediakan alatan berkuasa untuk I/O tidak menyekat. Berikut ialah contoh mudah pelayan tidak menyekat:
IntArrayList intList = new IntArrayList(); for (int i = 0; i < 1000000; i++) { intList.add(i); } int sum = intList.sum(); // Efficient sum operation
Pelayan ini boleh mengendalikan berbilang sambungan dengan cekap tanpa menimbulkan urutan baharu untuk setiap pelanggan.
Untuk aplikasi yang berurusan dengan fail besar, fail dipetakan memori boleh menawarkan peningkatan prestasi yang ketara. Mereka membenarkan anda merawat fail seolah-olah ia berada dalam ingatan, yang boleh menjadi lebih pantas daripada I/O tradisional untuk corak akses tertentu:
public class ExpensiveResource { private static ExpensiveResource instance; private ExpensiveResource() { // Expensive initialization } public static ExpensiveResource getInstance() { if (instance == null) { synchronized (ExpensiveResource.class) { if (instance == null) { instance = new ExpensiveResource(); } } } return instance; } }
Teknik ini amat berkesan untuk aplikasi yang memerlukan akses rawak kepada fail besar.
Kesimpulannya, mengoptimumkan aplikasi Java ialah proses berterusan yang memerlukan pemprofilan, analisis dan lelaran tetap. Dengan menggunakan enam teknik ini - pemprofilan, penalaan GC, memanfaatkan kompilasi JIT, menggunakan struktur data yang cekap, melaksanakan pengamulaan dan caching yang malas serta mengoptimumkan operasi I/O - anda boleh meningkatkan prestasi aplikasi Java anda dengan ketara.
Ingat, pengoptimuman prestasi selalunya tentang membuat pertukaran termaklum. Perkara yang paling berkesan untuk satu aplikasi mungkin tidak sesuai untuk aplikasi yang lain. Sentiasa ukur impak pengoptimuman anda dan bersedia untuk melaraskan pendekatan anda berdasarkan data prestasi dunia sebenar.
Akhir sekali, perlu diingat bahawa pengoptimuman pramatang boleh membawa kepada kerumitan yang tidak perlu. Mulakan dengan menulis kod yang bersih dan boleh dibaca, kemudian optimumkan berdasarkan hasil pemprofilan. Dengan teknik ini dalam kit alat anda, anda akan dilengkapkan dengan baik untuk menangani walaupun isu prestasi yang paling mencabar dalam aplikasi Java anda.
101 Buku ialah syarikat penerbitan dipacu AI yang diasaskan bersama oleh pengarang Aarav Joshi. Dengan memanfaatkan teknologi AI termaju, kami memastikan kos penerbitan kami sangat rendah—sesetengah buku berharga serendah $4—menjadikan pengetahuan berkualiti boleh diakses oleh semua orang.
Lihat buku kami Kod Bersih Golang tersedia di Amazon.
Nantikan kemas kini dan berita menarik. Apabila membeli-belah untuk buku, cari Aarav Joshi untuk mencari lebih banyak tajuk kami. Gunakan pautan yang disediakan untuk menikmati diskaun istimewa!
Pastikan anda melihat ciptaan kami:
Pusat Pelabur | Pelabur Central Spanish | Pelabur Jerman Tengah | Hidup Pintar | Epos & Gema | Misteri Membingungkan | Hindutva | Pembangunan Elit | Sekolah JS
Tech Koala Insights | Dunia Epok & Gema | Medium Pusat Pelabur | Medium Misteri Membingungkan | Sains & Zaman Sederhana | Hindutva Moden
Atas ialah kandungan terperinci Teknik Pengoptimuman JVM roven untuk Pembangun Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!