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

Menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak dalam pembangunan API Java

Jun 19, 2023 am 08:21 AM
java rabbitmq Pemprosesan tak segerak

Dalam proses pembangunan Java API, pemprosesan mesej tak segerak ialah teknologi yang sangat biasa. Pemprosesan mesej tak segerak boleh meningkatkan kelajuan tindak balas sistem dan meningkatkan kebolehskalaan sistem.

RabbitMQ ialah sistem baris gilir mesej sumber terbuka Ia menyediakan mekanisme penghantaran mesej yang mudah dan boleh dipercayai dan digunakan secara meluas dalam sistem yang diedarkan. Dalam pembangunan API Java, terdapat banyak faedah menggunakan RabbitMQ untuk pemprosesan mesej tak segerak. Artikel ini akan memperkenalkan cara menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak.

  1. Prasyarat

Sebelum mula menggunakan RabbitMQ2, anda perlu membuat persediaan berikut.

1.1 Pasang RabbitMQ

RabbitMQ ditulis berdasarkan Erlang, jadi Erlang perlu dipasang terlebih dahulu. Anda boleh memuat turun versi terkini Erlang dari https://www.erlang.org/downloads dan ikut wizard pemasangan untuk memasangnya.

Selepas memasang Erlang, anda boleh memasang RabbitMQ. Pakej pemasangan RabbitMQ boleh dimuat turun dari https://www.rabbitmq.com/download.html dan dipasang mengikut wizard pemasangan.

Selepas memasang RabbitMQ, anda perlu memulakan perkhidmatan RabbitMQ. Dalam sistem Linux/Mac, anda boleh menjalankan arahan berikut untuk memulakan perkhidmatan RabbitMQ:

sudo rabbitmq-server

Dalam sistem Windows, rabbitmq-server.bat boleh didapati dalam pemasangan RabbitMQ direktori, klik dua kali fail untuk memulakan perkhidmatan RabbitMQ.

1.2 Memperkenalkan kebergantungan RabbitMQ2

Menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak memerlukan pengenalan kebergantungan RabbitMQ2. Anda boleh membuka fail pom.xml projek dan menambah kandungan berikut di bawah teg :

<groupId>com.rabbitmq</groupId>
<artifactId>rabbitmq-client</artifactId>   
<version>5.5.1</version>
Salin selepas log masuk

  1. Pengenalan kepada konsep asas RabbitMQ2

Sebelum mula menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak, anda perlu memahami beberapa konsep asas RabbitMQ2.

2.1 Pengeluar

Pengeluar ialah pengeluar mesej dan bertanggungjawab menghantar mesej ke pelayan RabbitMQ.

2.2 Pengguna

Pengguna ialah pengguna mesej dan bertanggungjawab untuk menerima mesej daripada pelayan RabbitMQ dan memprosesnya.

2.3 Pertukaran

Pertukaran ialah pertukaran mesej, digunakan untuk menerima mesej yang dihantar oleh Pengeluar dan menghalakan mesej ke Baris Gilir yang sepadan.

2.4 Baris Gilir

Baris gilir ialah baris gilir mesej, digunakan untuk menyimpan mesej.

2.5 RoutingKey

RoutingKey ialah kunci penghalaan mesej, yang digunakan untuk menghalakan mesej dari Exchange ke Baris Gilir yang sepadan.

  1. Menggunakan RabbitMQ2

Setelah memahami konsep asas RabbitMQ2, anda boleh mula menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak. Berikut akan memperkenalkan cara menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak.

3.1 Sambung ke pelayan RabbitMQ

Sebelum menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak, anda perlu menyambung ke pelayan RabbitMQ terlebih dahulu. Anda boleh menggunakan kod berikut untuk menyambung:

ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
factory.setPort(5672);
kilang. setUsername( "guest");
factory.setPassword("guest");
Connection connection = factory.newConnection();

Dalam kod di atas, ConnectionFactory digunakan untuk membuat Sambungan ke pelayan RabbitMQ. Antaranya, setHost menetapkan nama hos pelayan RabbitMQ, setPort menetapkan nombor port pelayan RabbitMQ, setUsername dan setPassword masing-masing menetapkan nama pengguna dan kata laluan apabila menyambung ke pelayan RabbitMQ.

3.2 Menghantar mesej

Selepas berjaya menyambung ke pelayan RabbitMQ, anda boleh mula menghantar mesej. Mesej boleh dihantar menggunakan kod berikut:

Saluran saluran = connection.createChannel();
channel.queueDeclare("queue_name", false, false, false, null);
channel.basicPublish (" ", "queue_name", null, "message".getBytes());
channel.close();

Dalam kod di atas, connection.createChannel() digunakan untuk mencipta Saluran saluran. Pengisytiharan Queue boleh dilengkapkan melalui kaedah channel.queueDeclare() Parameter pertama kaedah ialah nama Queue Parameter kedua menunjukkan sama ada Queue yang berterusan. Parameter keempat menunjukkan sama ada Padamkan Baris secara automatik Parameter kelima ialah atribut Baris.

Penghantaran mesej diselesaikan melalui kaedah channel.basicPublish() Parameter pertama mewakili nama Exchange Anda boleh menghantar rentetan kosong untuk menunjukkan menggunakan Exchange lalai , menunjukkan bahawa mesej akan dihalakan Dalam Baris Gilir, parameter ketiga mewakili atribut mesej, null boleh dihantar dan parameter keempat mewakili kandungan mesej.

3.3 Terima mesej

Selepas menghantar mesej, anda boleh menggunakan kod berikut untuk menerima mesej:

Saluran saluran = connection.createChannel();
saluran .queueDeclare(" queue_name", false, false, false, null);
Consumer consumer = new DefaultConsumer(channel) {

@Override
public void handleDelivery(String consumerTag, Envelope envelope,
                           AMQP.BasicProperties properties, byte[] body) throws IOException {
    String message = new String(body, "UTF-8");
    System.out.println("Received: " + message);
}
Salin selepas log masuk

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

Dalam kod di atas, kaedah connection.createChannel() juga digunakan untuk mencipta saluran Saluran. Pengisytiharan Queue juga dilakukan menggunakan kaedah channel.queueDeclare(). Tentukan kaedah pemprosesan mesej dengan mencipta objek DefaultConsumer Kaedah handleDelivery() akan dipanggil apabila mesej diterima dan mesej perlu diproses dalam kaedah ini.

Penerimaan mesej dilengkapkan melalui kaedah channel.basicConsume() Parameter pertama menunjukkan baris gilir mesej yang akan diterima Parameter kedua menunjukkan sama ada untuk mengesahkan penerimaan mesej secara automatik objek Pengguna, menunjukkan Bagaimana mesej diproses.

Di atas adalah proses asas menggunakan RabbitMQ2 untuk pemprosesan mesej tak segerak. Dengan menggunakan RabbitMQ2, pemprosesan mesej tak segerak boleh menjadi sangat mudah dan kelajuan tindak balas dan kebolehskalaan sistem boleh dipertingkatkan.

Atas ialah kandungan terperinci Menggunakan RabbitMQ2 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

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)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 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.

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 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.

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