文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Docker搭建ActiveMQ消息服务的方法

2024-04-02 19:55

关注

这篇文章主要介绍“Docker搭建ActiveMQ消息服务的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Docker搭建ActiveMQ消息服务的方法”文章能帮助大家解决问题。

概念

jms消息模式

点对点或队列模式

包含三个角色:消息队列(queue),发送者(sender),接收者(receiver)。每个消息都被发送到一个特定的队列,接收者从队列中获取消息。队列保留着消息,直到他们被消费或超时。

pub/sub 发布/订阅模式

包含三个角色:主题(topic),发布者(publisher),订阅者(subscriber) 。多个发布者将消息发送到topic,系统将这些消息传递给多个订阅者。

为了缓和这样严格的时间相关性,jms允许订阅者创建一个可持久化的订阅。这样,即使订阅者没有被激活(运行),它也能接收到发布者的消息。

如果希望发送的消息可以不被做任何处理、或者只被一个消息者处理、或者可以被多个消费者处理的话,那么可以采用pub/sub模型。

jms消息基本组件

connectionfactory

创建connection对象的工厂,针对两种不同的jms消息模型,分别有queueconnectionfactory和topicconnectionfactory两种。可以通过jndi来查找connectionfactory对象。

destination

destination的意思是消息生产者的消息发送目标或者说消息消费者的消息来源。对于消息生产者来说,它的destination是某个队列(queue)或某个主题(topic);对于消息消费者来说,它的destination也是某个队列或主题(即消息来源)。

所以,destination实际上就是两种类型的对象:queue、topic可以通过jndi来查找destination。

connection

connection表示在客户端和jms系统之间建立的链接(对tcp/ip socket的包装)。connection可以产生一个或多个session。跟connectionfactory一样,connection也有两种类型:queueconnection和topicconnection。

session

session是操作消息的接口。可以通过session创建生产者、消费者、消息等。session提供了事务的功能。当需要使用session发送/接收多个消息时,可以将这些发送/接收动作放到一个事务中。同样,也分queuesession和topicsession。

消息的生产者

消息生产者由session创建,并用于将消息发送到destination。同样,消息生产者分两种类型:queuesender和topicpublisher。可以调用消息生产者的方法(send或publish方法)发送消息。

消息消费者

消息消费者由session创建,用于接收被发送到destination的消息。两种类型:queuereceiver和topicsubscriber。可分别通过session的createreceiver(queue)或createsubscriber(topic)来创建。当然,也可以session的creatdurablesubscriber方法来创建持久化的订阅者。

messagelistener

消息监听器。如果注册了消息监听器,一旦消息到达,将自动调用监听器的onmessage方法。ejb中的mdb(message-driven bean)就是一种messagelistener。

transport传输方式

activemq目前支持的transport有: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等。

 persistence持久化存储

amq message store

activemq 5.0 的缺省持久化存储方式。

kaha persistence

这是一个专门针对消息持久化的解决方案。它对典型的消息使用模式进行了优化。

jdbc persistence

目前支持的数据库有:apache derby, axion, db2, hsql, informix, maxdb, mysql, oracle, postgresql, sqlserver, sybase。

disable persistence

不应用持久化存储。

集群方案(master / slave)

pure master slave

 shared file system master slave

jdbc master slave

 安装说明

这里使用docker安装,查询docker镜像:

docker search activemq

下载docker镜像:

docker pull webcenter/activemq

创建&运行activemq容器:

docker run -d --name myactivemq -p 61617:61616 -p 8162:8161 webcenter/activemq

61616是 activemq 的容器使用端口(映射为61617),8161是 web 页面管理端口(对外映射为8162)

查看创建的容器,如果存在说明安装成功:

docker ps

查看web管理页面:

浏览器输入 http://ip :8162 点击manage activemq broker使用默认账号/密码:admin/admin进入查看。

Docker搭建ActiveMQ消息服务的方法

Docker搭建ActiveMQ消息服务的方法

配置访问密码

进入docker容器:

docker exec -it myactivemq /bin/bash

控制台界面设置用户名和密码:

# 位于根目录 conf 目录下
vi jetty-realm.properties

# 修改密码
# username: password [,rolename ...]
admin: admin, admin

配置连接密码

编辑activemq.xml文件,放置到 shutdownhooks 下方即可。

<!-- 添加访问activemq的账号密码 -->
<plugins>
  <simpleauthenticationplugin>
    <users>
      <authenticationuser username="${activemq.username}" password="${activemq.password}" groups="users,admins"/>
    </users>
  </simpleauthenticationplugin>
</plugins>

修改conf中credentials.properties文件进行密码设置:

activemq.username=admin
activemq.password=123456
guest.password=123456

注意事项

如果是云服务器,记得开放相关端口(61617/8160)

关于“Docker搭建ActiveMQ消息服务的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯