Network Security Internet Technology Development Database Servers Mobile Phone Android Software Apple Software Computer Software News IT Information

In addition to Weibo, there is also WeChat

Please pay attention

WeChat public account

Shulou

How to build ActiveMQ message Service in Docker

2025-01-19 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > Servers >

Share

Shulou(Shulou.com)06/01 Report--

This article is about how to build an ActiveMQ message service in Docker. The editor thinks it is very practical, so share it with you as a reference and follow the editor to have a look.

Preface

ActiveMQ is the most popular and powerful open source message bus produced by Apache. ActiveMQ is a JMS Provider implementation that fully supports JMS1.1 and J2EE 1.4. although it has been a long time since the introduction of JMS specification, JMS still plays a special role in today's J2EE applications.

In production projects, message middleware is often needed for communication between distributed systems. It has a series of functions, such as low coupling, reliable delivery, broadcast, flow control, final consistency and so on. This article mainly introduces the related concepts and installation instructions of ActiveMQ, and then focuses on the implementation of second-kill message queues with SpringBoot integration.

Concept

JMS message mode

Point-to-point or queue mode

Contains three roles: message queue (Queue), sender (Sender), and receiver (Receiver). Each message is sent to a specific queue from which the recipient gets the message. Queues retain messages until they are consumed or timed out.

There is only one Consumer per message, that is, once consumed, the message is no longer in the message queue.

There is no time dependence between the sender and the receiver, that is, when the sender sends the message, it does not affect the message being sent to the queue, regardless of whether the receiver is running or not.

The receiver needs to reply successfully to the queue after successfully receiving the message.

Pub/Sub publish / subscribe model

Contains three roles: topic (Topic), publisher (Publisher), and subscriber (Subscriber). Multiple publishers send messages to Topic, and the system delivers these messages to multiple subscribers.

There can be multiple consumers per message

There is a time dependence between publishers and subscribers. For subscribers to a topic (Topic), it must create a subscriber before it can consume the publisher's messages.

In order to consume messages, subscribers must keep running.

To ease this strict time correlation, JMS allows subscribers to create a persistent subscription. In this way, even if the subscriber is not activated (running), it can receive messages from the publisher.

If you want the message to be sent without any processing, or by only one messenger, or by multiple consumers, you can use the Pub/Sub model.

Basic components of JMS messages

ConnectionFactory

Create a factory for Connection objects for two different jms message models, QueueConnectionFactory and TopicConnectionFactory. You can find ConnectionFactory objects through JNDI.

Destination

Destination means the message producer's message delivery target or message consumer's message source. For message producers, its Destination is a queue (Queue) or a topic (Topic); for message consumers, its Destination is also a queue or topic (that is, a message source).

So, Destination is actually two types of objects: Queue and Topic can find Destination through JNDI.

Connection

Connection represents the link established between the client and the JMS system (the wrapper for TCP/IP socket). Connection can produce one or more Session. Like ConnectionFactory, there are two types of Connection: QueueConnection and TopicConnection.

Session

Session is the interface for manipulating messages. You can create producers, consumers, messages, and so on through session. Session provides the functionality of transactions. When you need to send / receive multiple messages using session, you can put these send / receive actions into a single transaction. Similarly, it is divided into QueueSession and TopicSession.

The producer of the message

The message producer is created by Session and used to send messages to Destination. Similarly, there are two types of message producers: QueueSender and TopicPublisher. You can call the message producer's method (send or publish method) to send the message.

Message consumer

Message consumers are created by Session to receive messages that are sent to Destination. There are two types: QueueReceiver and TopicSubscriber. It can be created through createReceiver (Queue) or createSubscriber (Topic) of session, respectively. Of course, the creatDurableSubscriber method of session can also be used to create persistent subscribers.

MessageListener

Message listener. If the message listener is registered, once the message arrives, the listener's onMessage method is automatically called. MDB (Message-Driven Bean) in EJB is a kind of MessageListener.

Transport transmission mode

Transport supported by ActiveMQ currently includes VM Transport, TCP Transport, NIO Transport, SSL Transport, Peer Transport, UDP Transport, Multicast Transport, HTTP and HTTPS Transport, WebSockets Transport, Failover Transport, Fanout Transport, Discovery Transport, ZeroConf Transport and so on.

VM Transport: allows clients and Broker to communicate directly within the VM, using a connection not a Socket connection, but a direct method call, thus avoiding the overhead of network transmission. The application scenario is also limited to Broker and the client in the same JVM environment.

TCP Transport: the client connects to the remote Broker through TCP Socket. Configuration syntax:

Tcp://hostname:port?transportOptions

HTTP and HTTPS Transport: allows clients to connect using REST or Ajax. This means that you can use Javascript to send messages directly to ActiveMQ.

WebSockets Transport: allows clients to connect to Broker through HTML5 standard WebSockets.

Failover Transport: this is the connection mode adopted by Azure Dragon system MQ. This method has the mechanism of automatic reconnection, which works on the upper layer of other Transport and is used to establish reliable transmission. Allows you to configure any number of URI, and this mechanism will automatically select one of the URI to try to connect. Configuration syntax:

Failover: (tcp://localhost:61616,tcp://localhost:61617,.)? transportOptions

Fanout Transport: mainly suitable for sending production messages to multiple agents. If multiple agents have loops, it may cause consumers to receive duplicate messages. Therefore, when using this protocol, it is best to send messages to multiple disconnected agents.

Persistence persistent storage

AMQ Message Store

The default persistent storage mode of ActiveMQ 5.0.

Kaha Persistence

This is a solution specifically for message persistence. It optimizes typical message usage patterns.

JDBC Persistence

Currently supported databases are: Apache Derby, Axion, DB2, HSQL, Informix, MaxDB, MySQL, Oracle, Postgresql, SQLServer, Sybase.

Disable Persistence

Persistent storage is not applied.

Cluster scheme (Master / Slave)

Pure Master Slave

No single point of failure

Do not need to rely on shared file system or shared database, use KahaDB to persist storage

A Master can only carry one Slave.

While Master is working, the message status is automatically synchronized to Slave

Once Master crashes, Slave automatically takes over, and messages that have been sent and not yet consumed continue to be valid

After Slave takes over, you must stop Slave to restart the previous Master

Shared File System Master Slave

JDBC Master Slave

In configuration, there is no distinction between Master and Slave. Broker with multiple shared data sources forms JDBC Master Slave.

The Broker that first grabs the resource (database lock) becomes Master, and other Broker regularly tries to preempt resources.

Once Master crashes, other Broker grabs resources, and only one eventually grabs it and immediately becomes Master. Even if the previous Master is restarted successfully, it can only wait as a Slave.

Installation instructions

Use Docker installation here to query the Docker image:

Docker search activemq

Download the Docker image:

Docker pull webcenter/activemq

Create & run the ActiveMQ container:

Docker run-d-- name myactivemq-p 61617 webcenter/activemq 61616-p 8162 webcenter/activemq

61616 is the container usage port for activemq (mapped to 61617), and 8161 is the web page management port (external mapping is 8162)

View the created container. If it exists, the installation is successful:

Docker ps

View the WEB management page:

Enter http://ip: 8162 in the browser and click Manage ActiveMQ broker to enter and view using the default account / password: admin/admin.

Configure access password

Enter the Docker container:

Docker exec-it myactivemq / bin/bash

The console interface sets the user name and password:

# vi jetty-realm.properties# password modification located in the root directory conf directory # username: password [, rolename...] admin: admin, admin

Configure the connection password

Edit the activemq.xml file and place it under shutdownHooks.

Modify the credentials.properties file in conf to set the password:

Activemq.username=adminactivemq.password=123456guest.password=123456

Matters needing attention

If it is a CVM, remember to open the relevant port (61617Universe 8160)

Thank you for reading! This is the end of the article on "how to build an ActiveMQ message service in Docker". I hope the above content can be of some help to you, so that you can learn more knowledge. if you think the article is good, you can share it for more people to see!

Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.

Views: 0

*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.

Share To

Servers

Wechat

© 2024 shulou.com SLNews company. All rights reserved.

12
Report