ActiveMQ的介绍及功能
参考百度ActiveMQ的下载https://activemq.apache.org/activemq-5113-release.html
另外,直接从官网下载,会有些慢,右键,检查,找到地址后用迅雷下载
下载的文件解压后如下:
安装及配置
和ActiveMQ相关的端口一共有两个,分别是消息通讯的端口61616,和管理控制台所需要的端口8161在conf/activemq.xml中能看到
用户名密码默认没有可配可不配
用户名密码信息保存在conf/jetty-realm.properties文件中
按顺序分别是:用户名、密码、角色名
另:ActiveMQ使用的是jetty服务器, 可以通过设置conf/jetty.xml文件,在进入控制台时不输入密码
将图示的属性value="true"改为"false",重新启动MQ登录时就不需要输入用户名和密码了
在conf/jeety.xml中找到如下的代码
所以如果有必要的话,防火墙是应该打开的。
在bin/win64下运行activemq.bat,如出现如下显示
然后访问8161,看到如下,就说明已经安装完成了
管理控制台默认的用户名密码是admin/admin
如果要修改,看conf/jetty-realm.properties
看懂了吧
安全机制
如果别人知道了我们activemq的ip及队列名,那么岂不是都可以给队列里发信息了?看这个页面
https://activemq.apache.org/security.html
在conf/activemq的broker节点中加入
- <plugins>
- <simpleAuthenticationPlugin>
- <users>
- <authenticationUser username="dlf" password="123" groups="users,admins"/>
- </users>
- </simpleAuthenticationPlugin>
- </plugins>
这说明我们ActiveMQ内部发送获取消息的用户名密码就是dlf/123
一个实例
我们把发邮件这个业务做成分布式的,一方提交发邮件的任务,一方发送
项目截图:
最开始的时候:
提交一个任务的时候
发送一个邮件之后:
收发邮件的源码
http://pan.baidu.com/s/1kVlM8mz