安装:
1、解压
tar -zxvf apache-activemq-5.15.8-bin.tar.gz
2、改名
mv apache-activemq-5.15.8 activemq515
3、开启端口
firewall-cmd --zone=public --add-port=8161/tcp --permanent
firewall-cmd --zone=public --add-port=61616/tcp --permanent
firewall-cmd --reload
4、启动停止
activemq start | stop
5、查看运行状态|日志
activemq status | start console
注意:
a、腾讯云启动activemq失败是因为主机名中含有下划线(VM_0_10_centos),mq要求主机名不包含下划线
b、查看主机名:查看静态、瞬态或灵活主机名,分别使用--static,--transient或--pretty选项
hostnamectl
c、修改主机名:
方法1:临时有效(只能临时修改的主机名,当重启机器后,主机名称又变回来了)
hostname vmcentos
方法2:永久生效(永久性的修改主机名称,重启后能保持修改后的)
hostnamectl set-hostname vmcentos
//删除hostname
hostnamectl set-hostname ""
d、手动更新/etc/hosts
vi /etc/hosts
一旦修改了静态主机名,/etc/hostname将被自动更新。然而/etc/hosts不会更新以保存所做的修改,所以你每次在修改主机名后一定要手动更新/etc/hosts,之后再重启CentOS7。否则系统再启动时会很慢。
6、访问,默认密码admin:admin
http://192.168.174.130:8161/
7、activemq安全设置(管理后台密码):
ActiveMQ使用的是jetty服务器, 打开conf/jetty.xml文件,找到
<bean id="securityConstraint" class="org.eclipse.jetty.http.security.Constraint">
<property name="name" value="BASIC" />
<property name="roles" value="admin" />
<property name="authenticate" value="false" />
</bean>
将property name为authenticate的属性value="false" 改为"true"
控制台的登录用户名密码保存在conf/jetty-realm.properties文件中,内容如下:
# username: password [,rolename ...] (格式| 用户名:密码,角色名)
admin: admin, admin
8、消息消费者密码认证
1)credentials.properties:(activemq的conf下)
activemq.username=system
activemq.password=manager
guest.password=password
2)在activemq.xml文件broker标签内加上
<plugins>
<simpleAuthenticationPlugin>
<users>
<authenticationUser username="${activemq.username}" password="${activemq.password}" groups="users,admins"/>
<authenticationUser username="guest" password="${guest.password}" groups="guests"/>
</users>
</simpleAuthenticationPlugin>
</plugins>
原生代码:
/**
* Created by tym on 2018/12/21 0021.
* 生产者
*/
public class QueueProducer {
public static void main(String[] args) throws JMSException {
//1、创建工厂
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://127.0.0.1:61616");
//2、创建连接
Connection conn = factory.createConnection();
//3、启动连接
conn.start();
//4、获取session 参数1:是否用事务 2:消息确认方式
Session session = conn.createSession(false,Session.AUTO_ACKNOWLEDGE);
//5、创建消息队列
Queue queue = session.createQueue("test_queue");
//6、创建消息生产者
MessageProducer mp = session.createProducer(queue);
//7、创建消息对象
//TextMessage tm = session.createTextMessage("欢迎来到消息队列!");
HashMap<String,Object> m = new HashMap<>();
m.put("id",250);m.put("name","admin");
ObjectMessage tm = session.createObjectMessage(m);
//8、发送消息
mp.send(tm);
//9、释放资源
mp.close();
session.close();
conn.close();
}
}
/**
* Created by tym on 2018/12/21 0021
* 消费者
*/
public class QueueConsumer {
public static void main(String[] args) throws JMSException, IOException {
//1、创建工厂
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://127.0.0.1:61616");
//2、创建连接
Connection conn = factory.createConnection();
//3、启动连接
conn.start();
//4、获取session 参数1:是否用事务 2:消息确认方式
Session session = conn.createSession(false,Session.AUTO_ACKNOWLEDGE);
//5、创建消息队列
Queue queue = session.createQueue("test_queue");
//6、创建消息消费者
MessageConsumer mc = session.createConsumer(queue);
//7、设置消息监听
mc.setMessageListener(new MessageListener() {
@Override
public void onMessage(Message message) {
if(message instanceof TextMessage){
TextMessage tm = (TextMessage)message;
try {
System.out.println("消费者收到消息:"+tm.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}else{
ObjectMessage tm = (ObjectMessage)message;
try {
System.out.println("消费者收到消息:"+tm.getObject());
} catch (JMSException e) {
e.printStackTrace();
}
}
}
});
//8、阻塞线程
System.in.read();
//9、释放资源
mc.close();
session.close();
conn.close();
}
}
//发布订阅模式只要修改第五步
//5、创建消息主题
Topic topic = session.createTopic("test_topic");
//带用户密码
ConnectionFactory connectionFactory =
new ActiveMQConnectionFactory("system","manager","tcp://localhost:61616");