ActiveMQ学习笔记(5)----Broker的启动方式
Broker:相当于一个ActiveMQ服务器实例,在实际的开发中我们可以启动多个Broker.
命令行启动参数示例如下:
1. activemq start 使用默认的activemq.xml来启动。
2. activemq start xbean:file../conf/active-2.xml来使用指定的配置文件来启动
3. 如果不指定file,也就是xbean:activemq-2.xml,那么xml必须在classpath下
使用ActiveMQ来构建Java运用
这里主要将ActiveMQ Broker作为独立的消息服务器来构建JAVA应用。
ActiveMQ也支持在vm中通信基于嵌入式的broker,能够无缝的集成其他的java应用。
1. 嵌入式Borker启动
BrokerService启动Broker,示例如下:
package com.wangx.activemq.broker; import org.apache.activemq.broker.BrokerFactory;
import org.apache.activemq.broker.BrokerService; import java.net.URI; public class InnerBroker { public static void main(String[] args) throws Exception {
//基于嵌入式的Broker启动broker
BrokerService broker = new BrokerService(); broker.setUseJmx(true);
//指定访问地址
broker.addConnector("tcp://localhost:8888");
broker.start();
}
}
使用前面的生产者和消费者,在初始化连接工厂时将链接改为tcp://localhost:8888,可以成功的发送和接收消息。
基于BrokerFactory启动broker,示例如下:
package com.wangx.activemq.broker; import org.apache.activemq.broker.BrokerFactory;
import org.apache.activemq.broker.BrokerService; import java.net.URI; public class InnerBroker { public static void main(String[] args) throws Exception {
//properties.properties 放到classpath下
String URI = "properties:properties.properties";
BrokerService brokerService = BrokerFactory.createBroker(new URI(URI));
brokerService.addConnector("tcp://localhost:8888");
brokerService.start();
}
}
properties.properties文件如下:
useJms=true
persistent=false
# 随意设置的broker的name
bokerName=Cheese
使用前面的生产者和消费者,在初始化连接工厂时将链接改为tcp://localhost:8888,可以成功的发送和接收消息。
使用Spring来集成Broker
首先引入Spring的核心以来。pom文件如下:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.1.2.RELEASE</version>
</dependency>
Spring配置文件如下applicationContext.xml:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.springframework.org/schema/beans"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd "> <!--使用最简单的Spring集成Broker,复杂的会有一些权限控制,这里先不演示
由于指定了init-method="start" destroy-method="stop" 所以这里的只需要读取spring的配置文件,将其装载到bean容器中,
启动和关闭broker都交由spring的生命周期来管理,使用 ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
启动,即可开启Broker,不需要任何多余的代码
-->
<bean id="broker" class="org.apache.activemq.broker.BrokerService" init-method="start" destroy-method="stop">
<property name="brokerName" value="myBroker"/>
<property name="persistent" value="false"/>
<property name="transportConnectorURIs">
<list>
<value>tcp://localhost:8888</value>
</list>
</property> </bean>
</beans>
使用最简单的Spring集成Broker,复杂的会有一些权限控制,这里先不演示,由于指定了init-method="start" destroy-method="stop" 所以这里的只需要读取spring的配置文件,将其装载到bean容器中,启动和关闭broker都交由spring的生命周期来管理,
使用 ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");启动,即可开启Broker,不需要任何多余的代码。启动类如下:
package com.wangx.activemq.spring; import org.apache.xbean.spring.context.ClassPathXmlApplicationContext;
import org.springframework.context.ApplicationContext; public class SpringBroker { public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
}
}
使用前面的生产者和消费者,在初始化连接工厂时将链接改为tcp://localhost:8888,可以成功的发送和接收消息。
还可以配置BrokerFactoryBean读取activemq.xml文件方式来集成Spring
bean配置如下:
<bean id="broker" class="org.apache.activemq.xbean.BrokerFactoryBean">
<property name="config" value="activema.xml"/>
<property name="start" value="true"/>
</bean>
2. ActiveMQ的启动
1. 可以通过在应用程序中以编码的方式启动broker,例如broker.start();
如果需要启动多个Broker,那么需要为每个broker设置不同的名字和host:port(地址)
例如:
package com.wangx.activemq.broker; import org.apache.activemq.broker.BrokerFactory;
import org.apache.activemq.broker.BrokerService; import java.net.URI; public class InnerBroker { public static void main(String[] args) throws Exception {
//基于嵌入式的Broker启动broker
BrokerService broker = new BrokerService(); broker.setUseJmx(true);
broker.setBrokerName("one");
//指定访问地址
broker.addConnector("tcp://localhost:8888");
broker.start();
}
}
2. 通过Spring启动,前面都已经演示过了。
ActiveMQ学习笔记(5)----Broker的启动方式的更多相关文章
- ActiveMQ学习笔记(5)——使用Spring JMS收发消息
摘要 ActiveMQ学习笔记(四)http://my.oschina.net/xiaoxishan/blog/380446 中记录了如何使用原生的方式从ActiveMQ中收发消息.可以看出,每次 ...
- (转)redis 学习笔记(1)-编译、启动、停止
redis 学习笔记(1)-编译.启动.停止 一.下载.编译 redis是以源码方式发行的,先下载源码,然后在linux下编译 1.1 http://www.redis.io/download 先 ...
- Windows phone 8 学习笔记(4) 应用的启动
原文:Windows phone 8 学习笔记(4) 应用的启动 Windows phone 8 的应用除了可以直接从开始菜单以及应用列表中打开外,还可以通过其他的方式打开.照片中心.音乐+视频中心提 ...
- go微服务框架kratos学习笔记四(kratos warden-quickstart warden-direct方式client调用)
目录 go微服务框架kratos学习笔记四(kratos warden-quickstart warden-direct方式client调用) warden direct demo-server gr ...
- .NET Remoting学习笔记(二)激活方式
目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 参考:百度百科 ♂风车车.Net 激活方式概念 在 ...
- 【转载】.NET Remoting学习笔记(二)激活方式
目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 参考:百度百科 ♂风车车.Net 激活方式概念 在访 ...
- Java学习笔记-多线程-创建线程的方式
创建线程 创建线程的方式: 继承java.lang.Thread 实现java.lang.Runnable接口 所有的线程对象都是Thead及其子类的实例 每个线程完成一定的任务,其实就是一段顺序执行 ...
- Android学习笔记1 android adb启动失败问题 adb server is out of date. killing...
下面是Android的学习笔记,原文地址. 我是使用adb devices出现如下红字错误, 使用第一种方法方法,结果关掉豌豆荚就可以了. android adb启动失败问题 adb server i ...
- Tornado学习笔记(一) helloword/多进程/启动参数
前言 当你觉得你过得很舒服的时候,你肯定没有在进步.所以我想学习新的东西,然后选择了Tornado.因为我觉得Tornado更匹配目前的我的综合素质. Tornado学习笔记系列主要参考<int ...
- ActiveMQ学习笔记(21)----ActiveMQ集成Tomcat
1. 监控和管理Broker Web Console 方式:直接访问ActiveMQ的管理页面:http://localhost:8161/admin,默认的用户名和密码是admin/admin.具体 ...
随机推荐
- Linux常见后缀缩写含义
ctl: control rc: run control (A run-control file is a file of declarations or commands associated wi ...
- LA 3635 Pie
题意:给出n个圆,分给n+1个人,求每个人最多能够得到多大面积的圆 二分每个人得到的圆的面积 #include<iostream> #include<cstdio> #incl ...
- Xcode7 下导入第三方库 图文介绍
网上没有很好的图文介绍,干脆我自己写一个好了,方便新手入门. 这里以导入著名的第三方网络库AFNetWorking v3.0.4和数据库FMDB v2.6.2为例进行说明. 好,下面开始. 下载源文件 ...
- CorelDRAW升级计划--如何购买
了解通过全新 CorelDRAW 2017升级计划更新此图形设计软件所有最新功能的实惠方案.助升级计划,您可以在下一主要产品版本推出时便收到该版本,从而始终使您的产品保持最新.升级计划取代为 X6 和 ...
- 三、Git 分支
使用分支意味着你可以把你的工作从开发主线上分离开来,以免影响开发主线.有人把 Git 的分支模型称为它的`‘必杀技特性’',也正因为这一特性,使得 Git 从众多版本控制系统中脱颖而出. 1.分支简介 ...
- 2015 Multi-University Training Contest 3 hdu 5324 Boring Class
Boring Class Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Tota ...
- UESTC 1143 数据传输 网络流 最大流 Dinic
数据传输 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...
- leetcode第一刷_Subsets II
要求子集,有很现成的方法.N个数.子集的个数是2^N.每一个元素都有在集合中和不在集合中两种状态,这些状态用[0,pow(2,N)]中每一个数来穷举,假设这个数中的第i位为1,说明当前集合中包括源数组 ...
- Solaris 10 改ip參考文档之二
參考自:Cannot change IP address of Solaris[TM] 10 host (Doc ID 1007942.1) 本文不做翻译.全文转载. Symptoms Changin ...
- 简单来说一下java中的泛型,ssh中dao层使用会简化代码量
原来仅仅是听老师说泛型特别好用,但是后来一直弄android用的泛型就比較少了.但是感觉它真的非常重要,于是花了一下午的时间写了个demo.好,老规矩.上代码: 首先,sysout是个工具,可是用着不 ...