In addition to Weibo, there is also WeChat
Please pay attention
WeChat public account
Shulou
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.
Continue with the installation of the previous hadoop.First, install zookooper1. Decompress zookoope
"Every 5-10 years, there's a rare product, a really special, very unusual product that's the most un
© 2024 shulou.com SLNews company. All rights reserved.