Rumah Java javaTutorial Menggunakan RabbitMQ untuk pemprosesan mesej tak segerak dalam pembangunan API Java

Menggunakan RabbitMQ untuk pemprosesan mesej tak segerak dalam pembangunan API Java

Jun 18, 2023 am 11:04 AM
java api rabbitmq

Dengan perkembangan pesat Internet, pemprosesan mesej tak segerak memainkan peranan penting dalam sistem teragih, yang boleh meningkatkan kebolehpercayaan dan keselarasan sistem. RabbitMQ ialah sistem baris gilir mesej sumber terbuka yang boleh menyampaikan mesej dengan cepat dan boleh dipercayai serta digunakan secara meluas dalam medan Internet. Artikel ini akan memperkenalkan cara menggunakan RabbitMQ untuk pemprosesan mesej tak segerak dalam pembangunan API Java.

1. Pengenalan kepada RabbitMQ

RabbitMQ ialah perisian tengah beratur mesej sumber terbuka berdasarkan AMQP (Advanced Message Qeuing Protocol). Ia ditulis dalam bahasa Erlang dan mempunyai ciri-ciri cepat, boleh dipercayai dan boleh skala. RabbitMQ menyokong berbilang bahasa pengaturcaraan, termasuk Java, Python, Ruby, dll., membolehkan pembangun menggunakannya dengan mudah.

2. Konsep asas RabbitMQ

1. Baris gilir mesej

Baris gilir mesej ialah struktur data FIFO (masuk dahulu, keluar dahulu) yang digunakan untuk menyimpan dan menghantar mesej. Dalam RabbitMQ, baris gilir mesej dipanggil "Barisan".

2. Mesej

Mesej ialah pembawa penghantaran maklumat dan boleh mengandungi sebarang jenis data. Dalam RabbitMQ, mesej dipanggil "Mesej".

3. Suis

Suis ialah pusat penghalaan mesej, menghantar mesej ke baris gilir yang sepadan mengikut peraturan. Dalam RabbitMQ, pertukaran itu dipanggil "Exchange".

4. Mengikat

Mengikat ialah operasi menyambungkan baris gilir dan suis bersama-sama, dan peraturan penghalaan tertentu boleh ditentukan. Biasanya, pengikatan dan baris gilir menentukan kunci penghalaan supaya suis boleh menghalakan mesej ke baris gilir yang betul.

5. Pengguna

Pengguna ialah program yang menerima dan memproses mesej. Ia boleh mengeluarkan mesej daripada baris gilir dan melakukan beberapa operasi. Dalam RabbitMQ, pengguna dipanggil "Pengguna".

3. Proses penggunaan RabbitMQ

Sebelum menggunakan RabbitMQ, anda perlu menyediakan pelayan RabbitMQ Untuk arahan pemasangan, sila rujuk dokumentasi rasmi. Proses asas adalah seperti berikut:

1 Buat objek kilang sambungan dan tetapkan alamat pelayan RabbitMQ dan nombor port.

ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
factory.setPort(5672);

2.

Sambungan sambungan = factory.newConnection();

3.

Saluran saluran = connection.createChannel();

4.

channel.exchangeDeclare("exchange_name", "direct", true);

5.

channel.queueDeclare("queue_name", true, false, false, null);

6.

channel.queueBind("queue_name", "exchange_name", "routing_key");

7. Cipta objek pengguna (Pengguna) dan tetapkan fungsi panggil balik penggunaan.

Pengguna pengguna = Pengguna Lalai(saluran) {

@Override
public void handleDelivery(String consumerTag, Envelope envelope,
                           AMQP.BasicProperties properties, byte[] body) throws IOException {
    // 处理消息
}
Salin selepas log masuk

};
channel.basicConsume("queue_name", benar, pengguna);

8 .

channel.basicPublish("exchange_name", "routing_key", null, message.getBytes());

4. Menggunakan RabbitMQ untuk pemprosesan mesej tak segerak

Dalam Java API Semasa pembangunan, terdapat banyak senario untuk menggunakan RabbitMQ untuk pemprosesan mesej tak segerak. Sebagai contoh, apabila pengguna menyerahkan permintaan tugas kepada sistem, permintaan itu boleh dibungkus ke dalam mesej dan diserahkan kepada baris gilir RabbitMQ. Sistem kemudiannya boleh memproses tugas semasa masa terbiar dan menghantar hasil pemprosesan ke baris gilir lain. Akhir sekali, bahagian lain program boleh mendapatkan hasil pemprosesan daripada baris gilir dan mengembalikannya kepada pengguna.

1 Buat objek kilang sambungan dan tetapkan alamat pelayan RabbitMQ dan nombor port.

ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
factory.setPort(5672);

2.

Sambungan sambungan = factory.newConnection();

3.

Saluran saluran = connection.createChannel();

4.

channel.exchangeDeclare("exchange_name", "direct", true);

5 Cipta objek giliran permintaan (Queue).

channel.queueDeclare("request_queue", true, false, false, null);

6.

channel.queueBind("request_queue", "exchange_name", "request_routing_key");

7 Cipta objek pengguna (Pengguna) dan tetapkan fungsi panggil balik penggunaan.

Pengguna pengguna = Pengguna Lalai(saluran) {

@Override
public void handleDelivery(String consumerTag, Envelope envelope,
                           AMQP.BasicProperties properties, byte[] body) throws IOException {
    // 处理请求消息
    String response = processMessage(new String(body));
    // 将处理结果发送到响应队列
    channel.basicPublish("exchange_name", "response_routing_key", null, response.getBytes());
}
Salin selepas log masuk

};
channel.basicConsume("request_queue", benar, pengguna);

8 Objek giliran.

channel.queueDeclare("response_queue", true, false, false, null);

9.

channel.queueBind("response_queue", "exchange_name", "response_routing_key");

10.

channel.basicPublish("exchange_name", "request_routing_key", null, requestMessage.getBytes());

11.

Respons penggunaConsumer = new DefaultConsumer(saluran) {

@Override
public void handleDelivery(String consumerTag, Envelope envelope,
                           AMQP.BasicProperties properties, byte[] body) throws IOException {
    // 处理响应消息
}
Salin selepas log masuk

};
channel.basicConsume("response_queue", true, responseConsumer);

5 🎜>

Artikel ini memperkenalkan proses asas menggunakan RabbitMQ untuk pemprosesan mesej tak segerak dalam pembangunan API Java. RabbitMQ boleh mencapai penghantaran mesej yang boleh dipercayai dan menyediakan kaedah pemprosesan mesej tak segerak yang cekap untuk sistem. Dalam pembangunan sebenar, konfigurasi yang berbeza perlu dipilih mengikut senario perniagaan yang berbeza untuk memastikan kebolehpercayaan dan prestasi sistem.

Atas ialah kandungan terperinci Menggunakan RabbitMQ untuk pemprosesan mesej tak segerak dalam pembangunan API Java. 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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

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

TimeStamp to Date in Java TimeStamp to Date in Java Aug 30, 2024 pm 04:28 PM

Panduan untuk TimeStamp to Date di Java. Di sini kita juga membincangkan pengenalan dan cara menukar cap waktu kepada tarikh dalam java bersama-sama dengan contoh.

Program Java untuk mencari kelantangan kapsul Program Java untuk mencari kelantangan kapsul Feb 07, 2025 am 11:37 AM

Kapsul adalah angka geometri tiga dimensi, terdiri daripada silinder dan hemisfera di kedua-dua hujungnya. Jumlah kapsul boleh dikira dengan menambahkan isipadu silinder dan jumlah hemisfera di kedua -dua hujungnya. Tutorial ini akan membincangkan cara mengira jumlah kapsul yang diberikan dalam Java menggunakan kaedah yang berbeza. Formula volum kapsul Formula untuk jumlah kapsul adalah seperti berikut: Kelantangan kapsul = isipadu isipadu silinder Dua jumlah hemisfera dalam, R: Radius hemisfera. H: Ketinggian silinder (tidak termasuk hemisfera). Contoh 1 masukkan Jejari = 5 unit Ketinggian = 10 unit Output Jilid = 1570.8 Unit padu menjelaskan Kirakan kelantangan menggunakan formula: Kelantangan = π × r2 × h (4

PHP vs Python: Memahami Perbezaan PHP vs Python: Memahami Perbezaan Apr 11, 2025 am 12:15 AM

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

PHP: Bahasa utama untuk pembangunan web PHP: Bahasa utama untuk pembangunan web Apr 13, 2025 am 12:08 AM

PHP adalah bahasa skrip yang digunakan secara meluas di sisi pelayan, terutamanya sesuai untuk pembangunan web. 1.PHP boleh membenamkan HTML, memproses permintaan dan respons HTTP, dan menyokong pelbagai pangkalan data. 2.PHP digunakan untuk menjana kandungan web dinamik, data borang proses, pangkalan data akses, dan lain -lain, dengan sokongan komuniti yang kuat dan sumber sumber terbuka. 3. PHP adalah bahasa yang ditafsirkan, dan proses pelaksanaan termasuk analisis leksikal, analisis tatabahasa, penyusunan dan pelaksanaan. 4.Php boleh digabungkan dengan MySQL untuk aplikasi lanjutan seperti sistem pendaftaran pengguna. 5. Apabila debugging php, anda boleh menggunakan fungsi seperti error_reporting () dan var_dump (). 6. Mengoptimumkan kod PHP untuk menggunakan mekanisme caching, mengoptimumkan pertanyaan pangkalan data dan menggunakan fungsi terbina dalam. 7

Cipta Masa Depan: Pengaturcaraan Java untuk Pemula Mutlak Cipta Masa Depan: Pengaturcaraan Java untuk Pemula Mutlak Oct 13, 2024 pm 01:32 PM

Java ialah bahasa pengaturcaraan popular yang boleh dipelajari oleh pembangun pemula dan berpengalaman. Tutorial ini bermula dengan konsep asas dan diteruskan melalui topik lanjutan. Selepas memasang Kit Pembangunan Java, anda boleh berlatih pengaturcaraan dengan mencipta program "Hello, World!" Selepas anda memahami kod, gunakan gesaan arahan untuk menyusun dan menjalankan program, dan "Hello, World!" Pembelajaran Java memulakan perjalanan pengaturcaraan anda, dan apabila penguasaan anda semakin mendalam, anda boleh mencipta aplikasi yang lebih kompleks.

Bagaimana untuk menjalankan aplikasi boot musim bunga pertama anda di Spring Tool Suite? Bagaimana untuk menjalankan aplikasi boot musim bunga pertama anda di Spring Tool Suite? Feb 07, 2025 pm 12:11 PM

Spring Boot memudahkan penciptaan aplikasi Java yang mantap, berskala, dan siap pengeluaran, merevolusi pembangunan Java. Pendekatan "Konvensyen Lebih Konfigurasi", yang wujud pada ekosistem musim bunga, meminimumkan persediaan manual, Allo

See all articles