异步消息总线hornetq学习-03客户端连接hornet进行jms消息的收发-非jndi方式连接
在上节中介绍了通过jndi方式连接到hornetq服务器上,有时候由于某些原因,我们不希望通过jndi方式连接,hornetq也支持这种方式进行
以第2章节的例子为模板,我们编写了另一个获取ConnectionFactory的方法createConnection
package com.crazycoder2010.hornetq; import java.util.HashMap;
import java.util.Properties; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.naming.InitialContext;
import javax.naming.NamingException; import org.hornetq.api.core.TransportConfiguration;
import org.hornetq.api.jms.HornetQJMSClient;
import org.hornetq.api.jms.JMSFactoryType;
import org.hornetq.core.remoting.impl.netty.NettyConnectorFactory;
import org.hornetq.core.remoting.impl.netty.TransportConstants; /**
* Hello world!
*
*/
public class App4 {
public static void main(String[] args) throws Exception {
Connection connection = null;
try{
connection = createConnection();
//connection = createConnectionWithJNDI();
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
MessageProducer messageProducer = session.createProducer(HornetQJMSClient.createQueue("exampleQueue"));
TextMessage message = session.createTextMessage("Kevin Test01");
System.out.println("Sent message: " + message.getText());
messageProducer.send(message); MessageConsumer consumer = session.createConsumer(HornetQJMSClient.createQueue("exampleQueue"));
connection.start();
Message received = consumer.receive(40);
System.out.println("received:"+received);
}finally{
releaseConnection(connection);
}
} private static void releaseConnection(Connection connection)
throws JMSException {
if(connection != null){
connection.close();
}
} private static Connection createConnection() throws JMSException {
HashMap<String, Object> map = new HashMap<String, Object>();
map.put(TransportConstants.HOST_PROP_NAME, "192.168.1.103");
map.put(TransportConstants.PORT_PROP_NAME, 5445);
TransportConfiguration server = new TransportConfiguration(NettyConnectorFactory.class.getName(), map); ConnectionFactory connectionFactory = (ConnectionFactory)HornetQJMSClient.createConnectionFactoryWithoutHA(JMSFactoryType.CF,server);
Connection connection = connectionFactory.createConnection();
return connection;
} private static Connection createConnectionWithJNDI() throws NamingException, JMSException{
Properties properties = new Properties();
properties.put("java.naming.factory.initial",
"org.jnp.interfaces.NamingContextFactory");
properties.put("java.naming.factory.url.pkgs",
"org.jboss.naming:org.jnp.interfaces");
properties.put("java.naming.provider.url", "jnp://192.168.1.103:1099");
InitialContext initialContext = new InitialContext(properties);
ConnectionFactory connectionFactory = (ConnectionFactory) initialContext
.lookup("/ConnectionFactory");
Connection connection = connectionFactory.createConnection();
return connection;
}
}
在如上的代码示例中,我们使用了hornetq客户端提供的一个静态工厂类来创建连接,要设置hornetq的连接地址和端口,这里我们使用默认的5445,这个例子只是在单机本地运行,因此调用HornetQJMSClient的xxxWithoutHA方法来执行,表示我们的连接不许要HA功能
异步消息总线hornetq学习-03客户端连接hornet进行jms消息的收发-非jndi方式连接的更多相关文章
- 使用redis客户端连接windows和linux下的redis并解决无法连接redis的问题
		
搭建环境:linux是centos7.4(请注意centos7以下版本的防火墙跟centos7以上的不同,使用redis客户端连接redis时会有区别,建议使用centos7以上版本) 一.下载red ...
 - EBS 消息总线
		
http://www.ibm.com/developerworks/cn/webservices/ws-whyesb/ 开发人员为何需要企业服务总线? 本文不仅仅是为架构师准备的:使用企业服务总线 ( ...
 - Redis基础知识之————如何处理客户端连接
		
redis 连接建立 Redis Redis 通过监听一个 TCP 端口或者 Unix socket 的方式来接收来自客户端的连接,当一个连接建立后,Redis 内部会进行以下一些操作: 首先,客户端 ...
 - SpringCloud实战8-Bus消息总线
		
好了现在我们接着上一篇的随笔,继续来讲.上一篇我们讲到,我们如果要去更新所有微服务的配置,在不重启的情况下去更新配置,只能依靠spring cloud config了,但是,是我们要一个服务一个服务的 ...
 - Redis如何处理客户端连接
		
本文主要介绍了 Redis 处理客户端连接的一些内部实现机制,包括连接处理.超时.缓冲区等一系列内容. 注:本文所述内容基于 Redis2.6 及以上版本. 连接的建立 Redis 通过监听一个 TC ...
 - Redis 处理客户端连接的一些内部实现机制
		
本文主要介绍了 Redis 处理客户端连接的一些内部实现机制,包括连接处理.超时.缓冲区等一系列内容. 注:本文所述内容基于 Redis2.6 及以上版本. 连接的建立 Redis 通过监听一个 TC ...
 - Android消息总线的演进之路:用LiveDataBus替代RxBus、EventBus
		
背景 对于Android系统来说,消息传递是最基本的组件,每一个App内的不同页面,不同组件都在进行消息传递.消息传递既可以用于Android四大组件之间的通信,也可用于异步线程和主线程之间的通信.对 ...
 - 八. SpringCloud消息总线
		
1. 消息总线概述 1.1 分布式配置的动态刷新问题 Linux运维修改Github上的配置文件内容做调整 刷新3344,发现ConfigServer配置中心立刻响应 刷新3355,发现ConfigC ...
 - PostgreSQL数据库服务端监听设置及客户端连接方法教程
		
众所周知,PostgreSQL 是一个自由的对象-关系数据库服务器(数据库管理系统),是一个可以免费使用的开放源代码数据库系统.本文详细介绍了PostgreSQL数据库服务端监听设置及客户端连接方法, ...
 
随机推荐
- <译>Selenium Python Bindings 6 - WebDriver API
			
本章涉及Selenium WebDriver的所有接口. Recommended Import Style 推荐的导入风格如下: from selenium import webdriver 然后,你 ...
 - opencv人脸检测分类器训练小结
			
这两天在初学目标检测的算法及步骤,其中人脸检测作为最经典的算法,于是进行了重点研究.该算法最重要的是建立人脸检测分类器,因此我用了一天的时间来学习分类器的训练.这方面的资料很多,但是能按照一个资料运行 ...
 - 【JAVA版】Storm程序整合Kafka、Mongodb示例及部署
			
一.环境 一台Centos6.5主机 Mongo 3.0 Kafka_2.11-0.8.2.1 Storm-0.9.5 Zookeeper-3.4.6 java 1.7 (后因在mac上打包的jar由 ...
 - openstack domain serverID connect uri
 - 我从其他人的Shell脚本中学到的
			
我从其他人的Shell脚本中学到的 2013/08/20 | 分类: 程序员 | 2 条评论 | 标签: SHELL, 脚本 分享到:17 本文由 伯乐在线 - 伯乐在线读者 翻译自 Fizer Kh ...
 - 【转】 Nginx系列(一)--nginx是什么?
			
原博文出于:http://blog.csdn.net/liutengteng130/article/details/46700939 感谢! 一.介绍 Nginx是一个高性能的HTTP和反向代理服务 ...
 - New full duplex HTTP tunnel implementation (client and server)
			
https://issues.jboss.org/browse/NETTY-246?page=com.atlassian.jirafisheyeplugin:fisheye-issuepanel —— ...
 - protobuf  作为配置文件
			
公司每个project代码中,都有一个Config类,作为模块启动的配置.其实现如下 struct Config { int num; char * file_name; int load_from_ ...
 - Delphi异形窗口之PNG
			
//1.单元内容 unit UnitAlienForm; interface uses Windows, Forms, Classes, Graphics; //从文件加载PNG procedure ...
 - codeforces 630D	Hexagons!
			
D. Hexagons! time limit per test 0.5 seconds memory limit per test 64 megabytes input standard input ...