1.activemq上传、解压安装
![](https://i-blog.csdnimg.cn/blog_migrate/4671d52d11b0cb8e62b67f39c6f333f0.png)
解压安装
2.移动activemq到指定目录
![](https://i-blog.csdnimg.cn/blog_migrate/40cd00a7ae4aa85e1680bac7202e6fa5.png)
3.配置activemq端口
ActiveMQ 需要用到两个端口
一个是消息通讯的端口(默认为 61616)
一个是管理控制台端口(默认为 8161)可在conf/jetty.xml 中修改,如下
指定jetty端口
![](https://i-blog.csdnimg.cn/blog_migrate/3f4a3c6b0e0b602ac73e34207f7f3583.png)
指定通讯端口
4.在防火墙中打开相应端口
![](https://i-blog.csdnimg.cn/blog_migrate/bd4cdef7c9b790cb940fa6d4c3fc3dca.png)
5.启动activemq
![](https://i-blog.csdnimg.cn/blog_migrate/9270b5f85990a3c4940c5bfd81472796.png)
在浏览器打开访问
![](https://i-blog.csdnimg.cn/blog_migrate/bdc424026fc0b3cb44d25e601aafe22c.png)
以admin/admin登录
![](https://i-blog.csdnimg.cn/blog_migrate/03039150cd16a0630302869cbc27133b.png)
登录成功
6.安全配置(消息安全)
ActiveMQ 如果不加入安全机制的话,任何人只要知道消息服务的具体地址(包括 ip,端口,消息地址 [队列或者主题地址 ], ),都可以肆无忌惮的发送、接收消息。关于 ActiveMQ 安装配置 http://activemq.apache.org/security.html
ActiveMQ 的消息安全配置策略有多种,我们以简单授权配置为例:在conf/activemq.xml 文件中在broker 标签最后加入以下内容即可:
![](https://i-blog.csdnimg.cn/blog_migrate/dbce2980e890166c9279cb9187e5a3cf.png)
定义了一个yixq 用户,密码为yxq123456,角色为users,admins
设置 admin 的用户名和密码:
确保 authenticate 的值为true(默认)
![](https://i-blog.csdnimg.cn/blog_migrate/2eeb6f5df843ff6a0e541e03c6facba6.png)
控制台的登录用户名密码保存在 conf/jetty-realm.properties 文件中,内容如下
![](https://i-blog.csdnimg.cn/blog_migrate/68f24361f5794fc160fefda53d874eec.png)
注意:用户名和密码的格式是
用户名 : 密码,角色名
重启,再登录就是新设置的密码登录
7.加入环境变量:
![](https://i-blog.csdnimg.cn/blog_migrate/3bda3de243fbe3bb92597b9e065b3a23.png)
8.设置开机启动:
# vi /etc/rc.local
加入:
su - yxq -c '/home/yxq/app/activemq/bin/activemq start'
MQ 消息生产者也与消息消费者的 Demo 样例讲解
消息提供方:
package com.edu.demo.mqtest;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.edu.demo.mqtest.MQProducer;
import com.edu.demo.mqtest.params.MailParam;
public class MQProducerTest {
private static final Log log = LogFactory.getLog(MQProducerTest.class);
public static void main(String[] args) {
try {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath:spring/spring-context.xml");
context.start();
MQProducer mqProducer = (MQProducer) context.getBean("mqProducer");
// 邮件发送
MailParam mail = new MailParam();
mail.setTo("18673132642@163.com");
mail.setSubject("ActiveMQ测试");
mail.setContent("通过ActiveMQ异步发送邮件!");
mqProducer.sendMessage(mail);
context.stop();
} catch (Exception e) {
log.error("==>MQ context start error:", e);
System.exit(0);
} finally {
log.info("===>System.exit");
System.exit(0);
}
}
}
package com.edu.demo.mqtest;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.edu.demo.mqtest.MQProducer;
import com.edu.demo.mqtest.params.MailParam;
public class MQProducerTest {
private static final Log log = LogFactory.getLog(MQProducerTest.class);
public static void main(String[] args) {
try {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath:spring/spring-context.xml");
context.start();
MQProducer mqProducer = (MQProducer) context.getBean("mqProducer");
// 邮件发送
MailParam mail = new MailParam();
mail.setTo("2779626653@163.com");
mail.setSubject("ActiveMQ测试");
mail.setContent("通过ActiveMQ异步发送邮件!");
mqProducer.sendMessage(mail);
context.stop();
} catch (Exception e) {
log.error("==>MQ context start error:", e);
System.exit(0);
} finally {
log.info("===>System.exit");
System.exit(0);
}
}
}
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-3.2.xsd"
- default-autowire="byName" default-lazy-init="false">
- <!-- 采用注释的方式配置bean -->
- <context:annotation-config />
- <!-- 配置要扫描的包 -->
- <context:component-scan base-package="com.edu.demo" />
- <!-- 读入配置属性文件 -->
- <context:property-placeholder location="classpath:mq.properties" />
- <!-- proxy-target-class默认"false",更改为"ture"使用CGLib动态代理 -->
- <aop:aspectj-autoproxy proxy-target-class="true" />
- <import resource="spring-mq.xml" />
- </beans>
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-3.2.xsd"
- default-autowire="byName" default-lazy-init="false">
- <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供 -->
- <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
- <!-- ActiveMQ服务地址 -->
- <property name="brokerURL" value="tcp://192.168.1.121:61616" />
- <property name="userName" value="yixq"></property>
- <property name="password" value="yxq123456"></property>
- </bean>
- <!--
- ActiveMQ为我们提供了一个PooledConnectionFactory,通过往里面注入一个ActiveMQConnectionFactory
- 可以用来将Connection、Session和MessageProducer池化,这样可以大大的减少我们的资源消耗。
- 要依赖于 activemq-pool包
- -->
- <bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory">
- <property name="connectionFactory" ref="targetConnectionFactory" />
- <property name="maxConnections" value="10" />
- </bean>
- <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
- <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
- <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
- <property name="targetConnectionFactory" ref="pooledConnectionFactory" />
- </bean>
- <!-- Spring提供的JMS工具类,它可以进行消息发送、接收等 -->
- <!-- 队列模板 -->
- <bean id="activeMqJmsTemplate" class="org.springframework.jms.core.JmsTemplate">
- <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->
- <property name="connectionFactory" ref="connectionFactory"/>
- <property name="defaultDestinationName" value="com.edu.mqtest.v1"></property>
- </bean>
- </beans>
pom.xml配置
- package com.edu.demo.mqtest;
- import org.apache.commons.logging.Log;
- import org.apache.commons.logging.LogFactory;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import com.edu.demo.mqtest.MQProducer;
- import com.edu.demo.mqtest.params.MailParam;
- public class MQProducerTest {
- private static final Log log = LogFactory.getLog(MQProducerTest.class);
- public static void main(String[] args) {
- try {
- ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath:spring/spring-context.xml");
- context.start();
- MQProducer mqProducer = (MQProducer) context.getBean("mqProducer");
- // 邮件发送
- MailParam mail = new MailParam();
- mail.setTo("2779626653@163.com");
- mail.setSubject("ActiveMQ测试");
- mail.setContent("通过ActiveMQ异步发送邮件!");
- mqProducer.sendMessage(mail);
- context.stop();
- } catch (Exception e) {
- log.error("==>MQ context start error:", e);
- System.exit(0);
- } finally {
- log.info("===>System.exit");
- System.exit(0);
- }
- }
- }
![](https://i-blog.csdnimg.cn/blog_migrate/d033dffa024914d2003879e145b5e91f.png)