Rumah Java javaTutorial Sejauh manakah pengaturcaraan serentak berbilang benang Java meningkatkan kecekapan pemprosesan data?

Sejauh manakah pengaturcaraan serentak berbilang benang Java meningkatkan kecekapan pemprosesan data?

Apr 28, 2023 pm 11:46 PM
java

    Dalam senario kerja, kami menghadapi keperluan sedemikian: untuk mengemas kini maklumat berkaitan model lain berdasarkan alamat IP hos. Keperluan adalah sangat mudah dan hanya melibatkan pertanyaan pautan pangkalan data umum dan operasi kemas kini Walau bagaimanapun, semasa proses pelaksanaan pengekodan, didapati bahawa disebabkan bilangan hos yang banyak, ia mengambil masa yang lama untuk membuat pertanyaan dan kemas kini kira-kira 30-40 saat untuk memanggil antara muka masa min untuk menyelesaikan operasi.

    Oleh itu, untuk memendekkan masa pelaksanaan kaedah antara muka dengan berkesan, pertimbangkan untuk menggunakan kaedah pengaturcaraan serentak berbilang benang, mengambil kesempatan daripada keupayaan pelaksanaan selari pemproses berbilang teras, dan memproses data secara tak segerak, yang boleh sangat memendekkan masa pelaksanaan dan meningkatkan kecekapan Pelaksanaan.

    Kolam benang boleh guna semula dengan bilangan benang tetap FixedThreadPool digunakan di sini dan alat kawalan proses serentak yang disediakan oleh kelas alat konkurensi CountDownLatch digunakan bersama untuk memastikan operasi normal semasa berbilang benang pengaturcaraan serentak:

    • Pertama , dapatkan bilangan utas CPU mesin yang sedang berjalan melalui kaedah Runtime.getRuntime().availableProcessors(), yang digunakan untuk menetapkan bilangan utas seterusnya dalam kolam benang tetap.

    • Kedua, , tentukan ciri-ciri tugasan tersebut Jika ia adalah tugasan yang intensif pengkomputeran, tetapkan bilangan utas kepada CPU 线程数+1 tugas intensif IO, tetapkan bilangan utas Untuk 2 * CPU 线程数, kerana interaksi kerap dengan pangkalan data diperlukan dalam kaedah, ia adalah tugas intensif IO.

    • Selepas itu, kumpulan dan potong data Setiap utas memproses satu data terkumpul Bilangan kumpulan terkumpul adalah konsisten dengan bilangan utas dan pembilang juga dibuat. Objek CountDownLatch, panggil pembina, dan mulakan nilai parameter kepada bilangan utas untuk memastikan bahawa utas utama menunggu semua sub-utas selesai dijalankan sebelum melakukan operasi seterusnya.

    • Kemudian , panggil kaedah executorService.execute(), tulis semula kaedah run untuk menulis logik perniagaan dan kod pemprosesan data, ingat untuk mengurangkan kaunter sebanyak 1 selepas melaksanakan operasi benang semasa. Akhir sekali, apabila semua benang kanak-kanak telah selesai dilaksanakan, tutup kumpulan benang.

    Selepas meninggalkan kod logik perniagaan dalam senario kerja, contoh kaedah pemprosesan umum adalah seperti berikut:

    public ResponseData updateHostDept() {
    		// ...
    		List<Map> hostMapList = mongoTemplate.find(query, Map.class, "host");
            // split the hostMapList for the following multi-threads task
            // return the number of logical CPUs
            int processorsNum = Runtime.getRuntime().availableProcessors();
            // set the threadNum as 2*(the number of logical CPUs) for handling IO Tasks,
            // if Computing Tasks set the threadNum as (the number of logical  CPUs) + 1
            int threadNum = processorsNum * 2;  
            // the number of each group data 
            int eachGroupNum = hostMapList.size() / threadNum; 
            List<List<Map>> groupList = new ArrayList<>();
            for (int i = 0; i < threadNum; i++) {
                int start = i * eachGroupNum;
                if (i == threadNum - 1) {
                    int end = mapList.size();
                    groupList.add(hostMapList.subList(start, end));
                } else {
                    int end = (i+1) * eachGroupNum;
                    groupList.add(hostMapList.subList(start, end));
                }
            }
            // update data by using multi-threads asynchronously
            ExecutorService executorService = Executors.newFixedThreadPool(threadNum/2);
            CountDownLatch countDownLatch = new CountDownLatch(threadNum);
            for (List<Map> group : groupList) {
                executorService.execute(()->{
                    try {
                        for (Map map : group) {
                        	// update the data in mongodb
                        }
                    } catch (Exception e) {
                        e.printStackTrace();
                    } finally {
                    	// let counter minus one 
                        countDownLatch.countDown();  
                    }
                });
            }
            try {
            	// main thread donnot execute until all child threads finish
                countDownLatch.await();  
            } catch (Exception e) {
                e.printStackTrace();
            }
            // remember to shutdown the threadPool
            executorService.shutdown();  
            return ResponseData.success();
    }
    Salin selepas log masuk

    Kemudian selepas menggunakan strategi kemas kini tak segerak berbilang benang, Anggaran masa yang diperlukan untuk memanggil antara muka telah menurun daripada 30-40 min kepada 8-10 min, meningkatkan kecekapan pelaksanaan.

    Perlu diambil perhatian bahawa newFixedThreadPool yang digunakan di sini untuk mencipta kumpulan benang mempunyai kecacatan bahawa baris gilir menyekatnya ialah baris gilir tidak terhad secara lalai, dan nilai lalai ialah Integer.MAX_VALUE yang sangat berkemungkinan Menyebabkan masalah OOM. Oleh itu, anda secara amnya boleh menggunakan ThreadPoolExecutor untuk mencipta kumpulan benang, dan anda boleh menentukan bilangan utas dalam baris gilir menunggu untuk mengelakkan masalah OOM.

    public ResponseData updateHostDept() {
    		// ...
    		List<Map> hostMapList = mongoTemplate.find(query, Map.class, "host");
            // split the hostMapList for the following multi-threads task
            // return the number of logical CPUs
            int processorsNum = Runtime.getRuntime().availableProcessors();
            // set the threadNum as 2*(the number of logical CPUs) for handling IO Tasks,
            // if Computing Tasks set the threadNum as (the number of logical  CPUs) + 1
            int threadNum = processorsNum * 2;  
            // the number of each group data 
            int eachGroupNum = hostMapList.size() / threadNum; 
            List<List<Map>> groupList = new ArrayList<>();
            for (int i = 0; i < threadNum; i++) {
                int start = i * eachGroupNum;
                if (i == threadNum - 1) {
                    int end = mapList.size();
                    groupList.add(hostMapList.subList(start, end));
                } else {
                    int end = (i+1) * eachGroupNum;
                    groupList.add(hostMapList.subList(start, end));
                }
            }
            // update data by using multi-threads asynchronously
            ThreadPoolExecutor executor = new ThreadPoolExecutor(5, 8, 30L, TimeUnit.SECONDS, 
                    new ArrayBlockingQueue<>(100));
            CountDownLatch countDownLatch = new CountDownLatch(threadNum);
            for (List<Map> group : groupList) {
                executor.execute(()->{
                    try {
                        for (Map map : group) {
                        	// update the data in mongodb
                        }
                    } catch (Exception e) {
                        e.printStackTrace();
                    } finally {
                    	// let counter minus one 
                        countDownLatch.countDown();  
                    }
                });
            }
            try {
            	// main thread donnot execute until all child threads finish
                countDownLatch.await();  
            } catch (Exception e) {
                e.printStackTrace();
            }
            // remember to shutdown the threadPool
            executor.shutdown();  
            return ResponseData.success();
    }
    Salin selepas log masuk

    Dalam kod di atas, bilangan utas teras dan bilangan maksimum utas masing-masing adalah 5 dan 8 Mereka tidak ditetapkan kepada nilai yang sangat besar, kerana jika ia ditetapkan kepada nilai yang besar , gangguan yang kerap antara benang akan berlaku juga akan meningkatkan penggunaan masa, tetapi tidak akan memaksimumkan kelebihan berbilang benang. Bagi cara memilih parameter yang sesuai, ia perlu ditentukan berdasarkan parameter mesin dan jenis tugas.

    Akhir sekali, jika anda ingin mendapatkan bilangan utas CPU mesin melalui kaedah bukan pengekodan, ia juga sangat mudah Dalam sistem Windows, anda boleh melihat bilangan utas CPU melalui Pengurus Tugas dan pilih "Prestasi". , seperti yang ditunjukkan dalam gambar di bawah:

    Sejauh manakah pengaturcaraan serentak berbilang benang Java meningkatkan kecekapan pemprosesan data?

    Seperti yang anda lihat daripada gambar di atas, teras dalam mesin saya ialah lapan CPU, tetapi satu fizikal Teras CPU boleh disimulasikan melalui teknologi hyper-threading ke dalam dua utas CPU logik, jadi mesin saya menyokong 8 teras dan 16 utas.

    Atas ialah kandungan terperinci Sejauh manakah pengaturcaraan serentak berbilang benang Java meningkatkan kecekapan pemprosesan data?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan Laman Web ini
    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

    Alat AI Hot

    Undresser.AI Undress

    Undresser.AI Undress

    Apl berkuasa AI untuk mencipta foto bogel yang realistik

    AI Clothes Remover

    AI Clothes Remover

    Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

    Undress AI Tool

    Undress AI Tool

    Gambar buka pakaian secara percuma

    Clothoff.io

    Clothoff.io

    Penyingkiran pakaian AI

    AI Hentai Generator

    AI Hentai Generator

    Menjana ai hentai secara percuma.

    Artikel Panas

    R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
    3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Tetapan grafik terbaik
    3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
    3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

    Alat panas

    Notepad++7.3.1

    Notepad++7.3.1

    Editor kod yang mudah digunakan dan percuma

    SublimeText3 versi Cina

    SublimeText3 versi Cina

    Versi Cina, sangat mudah digunakan

    Hantar Studio 13.0.1

    Hantar Studio 13.0.1

    Persekitaran pembangunan bersepadu PHP yang berkuasa

    Dreamweaver CS6

    Dreamweaver CS6

    Alat pembangunan web visual

    SublimeText3 versi Mac

    SublimeText3 versi Mac

    Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

    Akar Kuasa Dua di Jawa Akar Kuasa Dua di Jawa Aug 30, 2024 pm 04:26 PM

    Panduan untuk Square Root di Java. Di sini kita membincangkan cara Square Root berfungsi di Java dengan contoh dan pelaksanaan kodnya masing-masing.

    Nombor Sempurna di Jawa Nombor Sempurna di Jawa Aug 30, 2024 pm 04:28 PM

    Panduan Nombor Sempurna di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor Perfect dalam Java?, contoh dengan pelaksanaan kod.

    Penjana Nombor Rawak di Jawa Penjana Nombor Rawak di Jawa Aug 30, 2024 pm 04:27 PM

    Panduan untuk Penjana Nombor Rawak di Jawa. Di sini kita membincangkan Fungsi dalam Java dengan contoh dan dua Penjana berbeza dengan contoh lain.

    Nombor Armstrong di Jawa Nombor Armstrong di Jawa Aug 30, 2024 pm 04:26 PM

    Panduan untuk Nombor Armstrong di Jawa. Di sini kita membincangkan pengenalan kepada nombor Armstrong di java bersama-sama dengan beberapa kod.

    Weka di Jawa Weka di Jawa Aug 30, 2024 pm 04:28 PM

    Panduan untuk Weka di Jawa. Di sini kita membincangkan Pengenalan, cara menggunakan weka java, jenis platform, dan kelebihan dengan contoh.

    Nombor Smith di Jawa Nombor Smith di Jawa Aug 30, 2024 pm 04:28 PM

    Panduan untuk Nombor Smith di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor smith di Jawa? contoh dengan pelaksanaan kod.

    Soalan Temuduga Java Spring Soalan Temuduga Java Spring Aug 30, 2024 pm 04:29 PM

    Dalam artikel ini, kami telah menyimpan Soalan Temuduga Spring Java yang paling banyak ditanya dengan jawapan terperinci mereka. Supaya anda boleh memecahkan temuduga.

    Cuti atau kembali dari Java 8 Stream Foreach? Cuti atau kembali dari Java 8 Stream Foreach? Feb 07, 2025 pm 12:09 PM

    Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah

    See all articles