Rumah >Java >javaTutorial >Cara menggunakan Java untuk membangunkan aplikasi baris gilir mesej berprestasi tinggi berdasarkan Artemis

Cara menggunakan Java untuk membangunkan aplikasi baris gilir mesej berprestasi tinggi berdasarkan Artemis

PHPz
PHPzasal
2023-09-22 08:12:15842semak imbas

Cara menggunakan Java untuk membangunkan aplikasi baris gilir mesej berprestasi tinggi berdasarkan Artemis

Cara menggunakan Java untuk membangunkan aplikasi baris gilir mesej berprestasi tinggi berdasarkan Artemis

Pengenalan:
Dengan populariti Internet dan perkembangan teknologi maklumat, baris gilir mesej telah menjadi salah satu penyelesaian biasa untuk bangunan yang diedarkan sistem dan seni bina perkhidmatan mikro. Artemis ialah perisian tengah pemesejan yang berkuasa dan berprestasi tinggi yang sesuai untuk pelbagai senario aplikasi. Artikel ini akan memperkenalkan cara menggunakan Java untuk membangunkan aplikasi baris gilir mesej berprestasi tinggi berdasarkan Artemis dan menyediakan contoh kod khusus.

1. Persediaan

  1. Muat turun dan pasang JDK: Mula-mula kita perlu memuat turun dan memasang Java Development Kit (JDK) untuk memastikan sistem telah dipasang dan dikonfigurasikan dengan betul dengan pembolehubah persekitaran Java.
  2. Muat turun dan pasang Artemis: Seterusnya, kami perlu memuat turun perisian tengah mesej Artemis Anda boleh memuat turun versi terkini Artemis daripada laman web rasmi ActiveMQ (https://activemq.apache.org/artemis/).
  3. Buat projek baharu: Cipta projek Java baharu dalam persekitaran pembangunan anda dan import pakej balang Artemis yang berkaitan. Kebergantungan projek boleh diurus menggunakan alat binaan Maven atau Gradle.

2. Konfigurasikan Artemis

  1. Buat fail konfigurasi: Cipta fail konfigurasi bernama broker.xml dalam projek dan konfigurasikan kandungan berikut:
<configuration>
   <core xmlns="urn:activemq:core">
      <bindings-directory>./data/bindings</bindings-directory>
      <journal-directory>./data/journal</journal-directory>
      <large-messages-directory>./data/large-messages</large-messages-directory>
      <paging-directory>./data/paging</paging-directory>
      <connectors>
         <connector name="netty-connector">tcp://localhost:61616</connector>
      </connectors>
      <acceptors>
         <acceptor name="netty-acceptor">tcp://localhost:61616</acceptor>
      </acceptors>
   </core>
</configuration>

Fail konfigurasi di atas mentakrifkan storan dan sambungan perisian tengah mesej Artemis konfigurasi.

  1. Mulakan pelayan Artemis: Jalankan arahan berikut melalui baris arahan untuk memulakan pelayan Artemis:
./artemis run

3. Tulis kod Java

  1. Buat pengeluar
    Buat kelas bernama Producer dalam projek Java untuk menghantar mesej ke baris gilir mesej Artemis.
import javax.jms.*;

public class Producer {

    public static void main(String[] args) throws Exception {
        // 创建连接工厂
        ConnectionFactory factory = new org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory("tcp://localhost:61616");

        // 创建连接
        Connection connection = factory.createConnection();
        connection.start();

        // 创建会话
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

        // 创建目标
        Destination destination = session.createQueue("exampleQueue");

        // 创建生产者
        MessageProducer producer = session.createProducer(destination);

        // 创建消息
        TextMessage message = session.createTextMessage("Hello, Artemis!");

        // 发送消息
        producer.send(message);

        // 关闭连接
        session.close();
        connection.close();
    }
}
  1. Buat Pengguna
    Buat kelas yang dipanggil Consumer dalam projek Java anda untuk menerima mesej daripada baris gilir mesej Artemis.
import javax.jms.*;

public class Consumer implements MessageListener {

    public static void main(String[] args) throws Exception {
        // 创建连接工厂
        ConnectionFactory factory = new org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory("tcp://localhost:61616");

        // 创建连接
        Connection connection = factory.createConnection();
        connection.start();

        // 创建会话
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

        // 创建目标
        Destination destination = session.createQueue("exampleQueue");

        // 创建消费者
        MessageConsumer consumer = session.createConsumer(destination);
        consumer.setMessageListener(new Consumer());

        // 等待接收消息
        Thread.sleep(10000);

        // 关闭连接
        session.close();
        connection.close();
    }

    @Override
    public void onMessage(Message message) {
        try {
            // 处理接收到的消息
            if (message instanceof TextMessage) {
                TextMessage textMessage = (TextMessage) message;
                System.out.println("Received message: " + textMessage.getText());
            }
        } catch (JMSException e) {
            e.printStackTrace();
        }
    }
}

4. Jalankan kod

  1. Mulakan pengeluar: Jalankan fail Producer.java.
  2. Mulakan pengguna: Jalankan fail Consumer.java.
  3. Semak keputusan: Selepas pengeluar menghantar mesej, pengguna akan menerima dan mencetak mesej yang diterima.

Ringkasan:
Membangunkan aplikasi baris gilir mesej berprestasi tinggi berdasarkan Artemis menggunakan Java adalah tugas yang sangat praktikal dan mencabar. Artikel ini memperincikan cara mengkonfigurasi perisian tengah mesej Artemis dan menyediakan contoh kod Java untuk membantu pembaca mula membangunkan aplikasi baris gilir mesej mereka sendiri dengan cepat. Dengan mempelajari pengetahuan yang diterangkan dalam artikel ini, pembaca akan dapat mencipta sistem teragih yang berprestasi tinggi, boleh dipercayai dan seni bina perkhidmatan mikro.

Atas ialah kandungan terperinci Cara menggunakan Java untuk membangunkan aplikasi baris gilir mesej berprestasi tinggi berdasarkan Artemis. 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