zoukankan      html  css  js  c++  java
  • Activemq 平台搭建与C#示列

    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下配置好环境变量等,具体可以看 http://jingyan.baidu.com/article/ff41162596a77912e4823716.html
    3. 下载最新版activemq  http://activemq.apache.org/activemq-5121-release.html

    安装

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

    启动activemq服务

    启动成功后的界面是

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

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

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

    管理员界面如下

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

    摘自 http://www.cnblogs.com/hoojo/p/active_mq_jms_apache_activeMQ.html

    发送消息的基本步骤:

    (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,网址:http://activemq.apache.org/nms/download.html,需要下载Apache.NMS和Apache.NMS.ActiveMQ两个bin包

    http://www.apache.org/dyn/closer.lua/activemq/apache-nms/1.7.0/Apache.NMS.ActiveMQ-1.7.1-bin.zip

    创建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 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。

  • 相关阅读:
    C# 文件压缩与解压(ZIP格式)
    sqlite 报 no such table 错误
    又一次的轮回
    什么是数据结构
    紧张繁忙的一周
    《编程匠艺》读书笔记之十九
    [转]软件开发者面试百问
    关于学习设计模式的一些废话
    雷人的山寨版搜索引擎
    [转]Struts 2.1发布
  • 原文地址:https://www.cnblogs.com/woxpp/p/5001373.html
Copyright © 2011-2022 走看看