博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Activemq 平台搭建与C#示列
阅读量:7240 次
发布时间:2019-06-29

本文共 3813 字,大约阅读时间需要 12 分钟。

ActiveMQ

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。

特性

  1.  多种语言和协议编写客户端。语言: Java、C、C++、C#、Ruby、Perl、Python、PHP。应用协议:OpenWire、Stomp REST、WS Notification、XMPP、AMQP
  2. 完全支持JMS1.1和J2EE 1.4规范 (持久化,XA消息,事务)
  3. 对Spring的支持,ActiveMQ可以很容易内嵌到使用Spring的系统里面去,而且也支持Spring2.0的特性
  4. 通过了常见J2EE服务器(如 Geronimo、JBoss 4、GlassFish、WebLogic)的测试,其中通过JCA 1.5 resource adaptors的配置,可以让ActiveMQ可以自动的部署到任何兼容J2EE 1.4 商业服务器上
  5. 支持多种传送协议:in-VM、TCP、SSL、NIO、UDP、JGroups、JXTA
  6. 支持通过JDBC和journal提供高速的消息持久化
  7. 从设计上保证了高性能的集群,客户端-服务器,点对点
  8. 支持Ajax
  9. 支持与Axis的整合
  10. 可以很容易得调用内嵌JMS provider,进行测试

环境准备

我以windows7为列子

  1. windows 7
  2. jdk1.6+ 并在windows下配置好环境变量等,具体可以看
  3. 下载最新版activemq  

安装

解压下载好的安装包,至本地任何磁盘

启动activemq服务

启动成功后的界面是

如果出现major.minor version51.0 之类的错误,都是java版本安装错误的问题,安装1.6+以上的版本就能解决

启动成功后,,默认用户名和密码admin/admin。如果你想修改用户名和密码的话,在conf/jetty-realm.properties中修改即可。

如果需要修改端口可以在jetty文件中修改

管理员界面如下

ActiviteMQ接收和发送消息基本流程

摘自

发送消息的基本步骤:

(1)、创建连接使用的工厂类JMS ConnectionFactory

(2)、使用管理对象JMS ConnectionFactory建立连接Connection,并启动

(3)、使用连接Connection 建立会话Session

(4)、使用会话Session和管理对象Destination创建消息生产者MessageSender

(5)、使用消息生产者MessageSender发送消息 

消息接收者从JMS接受消息的步骤

(1)、创建连接使用的工厂类JMS ConnectionFactory

(2)、使用管理对象JMS ConnectionFactory建立连接Connection,并启动

(3)、使用连接Connection 建立会话Session

(4)、使用会话Session和管理对象Destination创建消息接收者MessageReceiver

(5)、使用消息接收者MessageReceiver接受消息,需要用setMessageListener将MessageListener接口绑定到MessageReceiver消息接收者必须实现了MessageListener接口,需要定义onMessage事件方法。

 

C#消息队列写入

ActiveMQ官方网站下载最新版的Apache.NMS,网址:,需要下载Apache.NMS和Apache.NMS.ActiveMQ两个bin包

创建C#项目,将这两个DLL添加到项目中。

写入地址如下

写入账号,密码如下

写入代码如下:

namespace ConsoleApplication21{    class Program    {        static void Main(string[] args)        {            String QueuesNameESF = "queue://test.log";            Uri _uri = new Uri(String.Concat("activemq:tcp://10.58.8.239:61616"));            IConnectionFactory factory = new ConnectionFactory(_uri);            using (IConnection conn = factory.CreateConnection("admin", "manager"))            {                using (ISession session = conn.CreateSession())                {                    IDestination destination = SessionUtil.GetDestination(session, QueuesNameESF);                     using (IMessageProducer producer = session.CreateProducer(destination))                    {                        conn.Start();                        //可以写入字符串,也可以是一个xml字符串等                        ITextMessage request = session.CreateTextMessage("messsage");                        producer.Send(request);                    }                }            }        }    }

写入后,可以查看

 

读取代码如下:

 

using System;using Apache.NMS;using Apache.NMS.ActiveMQ;using Apache.NMS.Util;namespace ConsoleApplication21{    class Program    {        static void Main(string[] args)        {            String QueuesNameESF = "queue://test.log";            Uri _uri = new Uri(String.Concat("activemq:tcp://10.58.8.239:61616?wireFormat.maxInactivityDuration=0"));            IConnectionFactory factory = new ConnectionFactory(_uri);            using (IConnection conn = factory.CreateConnection("admin", "manager"))            {                using (ISession session = conn.CreateSession())                {                    conn.Start();                    IDestination destination = SessionUtil.GetDestination(session, QueuesNameESF);                    using (IMessageConsumer consumer = session.CreateConsumer(destination))                    {                        ITextMessage message = consumer.Receive() as ITextMessage;                        Console.Write(message.Text);                    }                }            }            Console.ReadLine();        }    }}

 

 

作者:释迦苦僧 出处:http://www.cnblogs.com/woxpp/p/5001373.html 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。

转载于:https://www.cnblogs.com/woxpp/p/5001373.html

你可能感兴趣的文章
WIN内核线程池函数
查看>>
机器学习常见算法个人总结(面试用)
查看>>
T4 好用的Vs扩展
查看>>
Swift3.0 split函数切割字符串
查看>>
字典树
查看>>
单例模式的七种写法
查看>>
extjs_08_界面布局
查看>>
卷积神经网络(CNN)代码实现(MNIST)解析
查看>>
git 在命令行与图形状态下使用详情
查看>>
爱上MVC~Web.Config的Debug和Release版本介绍
查看>>
linux操作系统中oracle数据库的密码过期问题解决
查看>>
Spring中Bean的五个作用域
查看>>
hadoop之 distcp(分布式拷贝)
查看>>
Java后端程序员1年工作经验总结
查看>>
使用Vundle管理配置Vim的插件
查看>>
JDBC连接池&DBUtils使用
查看>>
可以通过shadowserver来查看开放的mdns(用以反射放大攻击)——中国的在 https://mdns.shadowserver.org/workstation/index.html...
查看>>
IOS系统控件高度
查看>>
Flink - ResultPartition
查看>>
2017.10.09 穆瑞课KUKA机器人培训视频的感想
查看>>