Windows环境下消息中间件RabbitMq的搭建与应用
前言
消息中间件目前已经在很多大型的项目上得到了运用,我们常见的有 RabbitMq, activitymq,kafka,rocketmq,其中rocketmq是阿里自己在kafka的基础上用java写的一个消息中间件。在我们使用的支付宝等应用中都有大量的使用。
附几种常见的mq对比图如下:
环境搭建
我们都知道大部分情况下都是在linux系统下部署服务。但是本篇的环境是在Windows下。
1.安装Erlang
rabbitMQ是一个在AMQP协议标准基础上完整的,可服用的企业消息系统。它遵循Mozilla Public License开源协议,采用 Erlang 实现的工业级的消息队列(MQ)服务器,Rabbit MQ 是建立在Erlang OTP平台上。所以在安装rabbitMQ之前,需要先安装Erlang 。
http://www.erlang.org/download/otp_win32_R16B03.exe,需要其他版本或者64位系统的,可以去官网下载。
全部点击“下一步”就行。
有的选择其他的安装方式,可能需要添加一下系统环境变量
2.安装RabbitMQ
下载运行 :http://www.rabbitmq.com/releases/rabbitmq-server/v3.2.3/rabbitmq-server-3.2.3.exe ,需要其他版本或者64位系统的,可以去官网下载。
依旧可以不改变默认进行安装。
需要注意:默认安装的RabbitMQ 监听端口是5672
3.配置
激活 RabbitMQ's Management Plugin
使用RabbitMQ 管理插件,可以更好的可视化方式查看Rabbit MQ 服务器实例的状态。
打开命令窗口:
输入命令:
- "C:\Program Files\RabbitMQ Server\rabbitmq_server-3.2.3\sbin\rabbitmq-plugins.bat" enable rabbitmq_management
重启服务才行,使用命令:
- net stop RabbitMQ && net start RabbitMQ
这时候,也许会出现这种结果:
“发生错误:发生系统错误 5。 拒绝访问。”
问题解决方案:使用管理员打开cmd再执行此命令:
在C:\Windows\System32 找到cmd.exe 双击执行。
创建用户,密码,绑定角色
使用rabbitmqctl控制台命令(位于C:\Program Files\RabbitMQ Server\rabbitmq_server-xxx\sbin>)来创建用户,密码,绑定权限等。
注意:安装路径不同的请看仔细啊。
rabbitmq的用户管理包括增加用户,删除用户,查看用户列表,修改用户密码。
新增一个用户:
- rabbitmqctl.bat add_user username password
查看已有用户及用户的角色:
- rabbitmqctl.bat list_users
此时来看下我们当前用户后面没有“[administrator]”
这个administrator是干嘛用的呢?这就涉及到用户角色问题了:
rabbitmq用户角色可分为五类:超级管理员, 监控者, 策略制定者, 普通管理者以及其他。
(1) 超级管理员(administrator)
可登陆管理控制台(启用management plugin的情况下),可查看所有的信息,并且可以对用户,策略(policy)进行操作。
(2) 监控者(monitoring)
可登陆管理控制台(启用management plugin的情况下),同时可以查看rabbitmq节点的相关信息(进程数,内存使用情况,磁盘使用情况等)
(3) 策略制定者(policymaker)
可登陆管理控制台(启用management plugin的情况下), 同时可以对policy进行管理。
(4) 普通管理者(management)
仅可登陆管理控制台(启用management plugin的情况下),无法看到节点信息,也无法对策略进行管理。
(5) 其他的
无法登陆管理控制台,通常就是普通的生产者和消费者
我们也给新建的用户username 变成 “超级管理员” 角色:
rabbitmqctl.bat set_user_tags username administrator
修改密码:
rabbitmqctl change_password userName newPassword
删除已存在的用户:
rabbitmqctl.bat delete_user username
这样基本的配置就结束了。
然后我们打开浏览器 http://localhost:15672访问Rabbit Mq的管理控制台,使用刚才创建的账号登陆系统:
设置虚拟主机和用户关系(默认虚拟主机名为 "/”),选中admin菜单,然后选中右边的 virtual hosts 菜单,如下图:
在最下面有一个添加虚拟主机,我们自己起好名称点击 add virtual host 即可。
然后再上面的列表中就可以看到你新添加的主机,再点击你新添加的虚拟主机,为其分配用户,我们首先可以分配我们前面创建的username 用户,然后也可以在admin→users页面添加新的用户后,再将其添加到当前新建的虚拟主机。
对于这块虚拟主机和用户,我个人的理解就像是你买了一辆车(用户),我买了一辆车(用户), 但是我们都得去交管所上拍照(虚拟主机)。
java代码编写
现在环境搭好,开始进行code。
新建一个maven工程,新手可参考 https://www.cnblogs.com/JJJ1990/p/8384386.html 前半部分。
在pom文件中添加jar包引用
- <dependency>
- <groupId>com.rabbitmq</groupId>
- <artifactId>amqp-client</artifactId>
- <version>3.6.5</version>
- </dependency>
发布者
- public static void publisher()
- {
- Connection connection = null;
- Channel channel = null;
- try
- {
- ConnectionFactory factory = new ConnectionFactory();
- factory.setHost(ConnectionFactory.DEFAULT_HOST); //设置连接地址 默认 localhost
- factory.setPort(ConnectionFactory.DEFAULT_AMQP_PORT); //监听端口 默认5672
- factory.setUsername("username"); //用户名
- factory.setPassword("password"); //密码
- factory.setVirtualHost("test_vhosts"); // 虚拟主机
- //创建与RabbitMQ服务器的TCP连接
- connection = factory.newConnection();
- channel = connection.createChannel(); //创建通道/频道
- channel.queueDeclare("JQueue", true, false, false, null); //参数中的 JQueue就是我们声明的队列名称
- String message = "First Message"; //消息体
- channel.basicPublish("", "JQueue", null, message.getBytes());
- System.out.println("Send Message is:'" + message + "'");
- }
- catch(Exception ex)
- {
- ex.printStackTrace();
- }
- finally
- {
- if(channel != null)
- {
- try {
- channel.close();
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (TimeoutException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- if(connection != null)
- {
- try {
- connection.close();
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- }
- }
我们先新建一个publisher()方法,在引入jar包的时候要特别注意,同样的名称有好几个包,我们统一都只引用 com.rabbitmq.client。
在queueDeclare方法中 除了队列名称外的其余4项参数意义如下
* @param durable true if we are declaring a durable queue (the queue will survive a server restart)
* @param exclusive true if we are declaring an exclusive queue (restricted to this connection)
* @param autoDelete true if we are declaring an autodelete queue (server will delete it when no longer in use)
* @param arguments other properties (construction arguments) for the queue
消费者
- public static void consumer() {
- Connection connection = null;
- Channel channel = null;
- try
- {
- ConnectionFactory factory = new ConnectionFactory();
- factory.setHost(ConnectionFactory.DEFAULT_HOST);
- factory.setPort(ConnectionFactory.DEFAULT_AMQP_PORT);
- factory.setUsername("jjj"); //注意此处的用户名和发布者不同,但是我将他们分配到了同一个虚拟主机,同样可以获取发布的消息
- factory.setPassword("password");
- factory.setVirtualHost("test_vhosts");
- connection = factory.newConnection();
- channel = connection.createChannel();
- Consumer consumer = new DefaultConsumer(channel) {
- @Override
- public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body)
- throws IOException {
- String message = new String(body, "UTF-8");
- System.out.println(" Consumer have received '" + message + "'");
- }
- };
- channel.basicConsume("JQueue", true, consumer); //绑定消费者和队列
- }
- catch(Exception ex)
- {
- ex.printStackTrace();
- }
- }
对比消费者和发布者的代码我们可以发现,我用了不同的用户连接同一个虚拟主机 test_vhosts
新建main方法
- public static void main( String[] args )
- {
- publisher();
- System.out.println( "Hello World!消息已經发布" );
- consumer();
- System.out.println( "Hello World!正在监听接收" );
- }
运行代码后可以看到如下结果:
浏览器打开rabbitmq界面。找到queues 菜单,点击后,就可以在列表中找到我们建立的队列,找到我刚才新建的jqueue队列,点进去后,找到下面的 publish message 目录
在Payload 中我们随便输入一些文字 点击发布就可以看到代码的控制台已经收到了这些消息
控制台输出:
这说明程序运行后,消费者一直在监听当前的队列,一旦有消息,就会立刻获取。
Windows环境下消息中间件RabbitMq的搭建与应用的更多相关文章
- 番外篇:搭建Windows环境下的RabbitMQ环境
搭建Windows环境下的Rabbitmq环境 下载erlang语言包OTP.官网地址: https://www.erlang.org/downloads 如果下载不了,可以选择百度网盘下载,里面的版 ...
- Windows环境下ELK平台的搭建
.背景 日志主要包括系统日志.应用程序日志和安全日志.系统运维和开发人员可以通过日志了解服务器软硬件信息.检查配置过程中的错误及错误发生的原因.经常分析日志可以了解服务器的负荷,性能安全性,从而及时采 ...
- Windows环境下的jekyll本地搭建
一.配置ruby环境 由于jekyll是用ruby语言写的一个静态网页生成工具,所以要搭建jekyll本地环境就需要先配置好ruby环境. 1)去官网下载Ruby:https://www.ruby-l ...
- windows环境下安装rabbitmq及配置可视化管理界面
1.环境 windows7 64位 rabbitmq3.7.9 erlang10.22.先安装erlang,后安装rabbitmq.下载地址: rabbitmq http://www.rabbitmq ...
- Windows环境下安装RabbitMQ
本地安装RabbitMQ安装注意事项: Erlang与RabbitMQ,安装路径都应不含空格符. Erlang使用了环境变量HOMEDRIVE与HOMEPATH来访问配置文件.erlang.cooki ...
- 【windows环境下】RabbitMq的安装和监控插件安装
RabbitMq的安装: RabbitMQ是基于Erlang的,所以必须先配置Erlang环境. 下载Erlang,地址:http://www.erlang.org/download/otp_win3 ...
- Windows环境下用jwplayer+Nginx搭建视频点播服务器
flv视频可以采用两种方式发布: 一.普通的HTTP下载方式 二.基于Flash Media Server或Red5服务器的rtmp/rtmpt流媒体方式. 多数知名视频网站都采用的是前一种方式. 两 ...
- Windows环境下sublime text 3搭建前端开发环境
一.安装SubLime Text 3 SubLime Text 3官网下载:https://www.sublimetext.com/ 二.安装Package Control 进入sublime后,按快 ...
- Windows环境下ELK(5.X)平台的搭建
一.Windows环境下ELK平台的搭建(2.*) 1.安装配置Java环境 在Oracle官网获取最新版的Java版本,由于只是运行不是开发,所以也可以只下载JRE.官网:http://www.or ...
随机推荐
- .net core2.0通过entityframework访问Sqlserver数据库
.net core经历2.0版本之后,已经非常稳定,完全可以进行企业级开发并跨平台部署到几乎任何服务器.个人测试效率是.net core是.net framework效率的3倍.其他语言没有测试,等测 ...
- Android Studio 插件开发详解四:填坑
转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/78265540 本文出自[赵彦军的博客] 在前面我介绍了插件开发的基本流程 [And ...
- Ocelot中文文档-负载均衡
Ocelot能通过可用的下游服务对每个ReRoute进行负载平衡. 这意味着您可以扩展您的下游服务,并且Ocelot可以有效地使用它们. 可用的负载均衡器的类型是: LeastConnection - ...
- Maven的使用
在项目中,我们通常会为项目添加多种多样的依赖包(jar包),去网上下载,然后引入到项目中,很是麻烦. 但是用maven后,这一切都将变得简单起来.由于我的MyEclipse已经集成了maven插件,这 ...
- 架构之微服务(zookeeper)
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等.Zookeeper是hadoop的一个子项目,其 ...
- Hadoop-Yarn-框架原理及运作机制
一.YARN基本架构 YARN是Hadoop 2.0中的资源管理系统,它的基本设计思想是将MRv1中的JobTracker拆分成了两个独立的服务:一个全局的资源管理器ResourceManager和每 ...
- 创建servlet的三种方式
第一种方式,实现Servlet接口 package com.example.servlet; import java.io.IOException; import javax.servlet.Serv ...
- 团队项目第二阶段个人进展——Day4
一.昨天工作总结 冲刺第四天,分析完成后端处理的数据有主题,时间,地点,照片信息,前几个都是字符串类型,后一个是照片格式 二.遇到的问题 照片格式数据不知道怎么处理 三.今日工作规划 学习后端小程序后 ...
- 什么是分布式锁及正确使用redis实现分布式锁
分布式锁 分布式锁其实可以理解为:控制分布式系统有序的去对共享资源进行操作,通过互斥来保持一致性. 举个不太恰当的例子:假设共享的资源就是一个房子,里面有各种书,分布式系统就是要进屋看书的人,分布式锁 ...
- List数组和集合相互转换
1.List的toArray()方法用于将集合转换成数组,但实际上改方法是在Collection中定义的,所以所有的集合都具备这个功能, 其有两个方法:Object[] toArray() 和 ...