设为首页 收藏本站
查看: 1104|回复: 0

[经验分享] RabbitMQ安装配置和基于EasyNetQ驱动的基础使用

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-7-2 11:19:19 | 显示全部楼层 |阅读模式
RabbitMQ基本概念和原理
  1.AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。
  2.RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写。
  3.Channel
  Channel是我们与RabbitMQ打交道的最重要的一个接口,我们大部分的业务操作是在Channel这个接口中完成的,包括定义Queue、定义Exchange、绑定Queue与Exchange、发布消息等。
  4.Exchange(生产者将消息发送到Exchange(交换器),由Exchange将消息路由到一个或多个Queue中(或者丢弃),RabbitMQ常用的Exchange Type有fanout、direct、topic、headers这四种)
  5.Queue(RabbitMQ的内部对象,用于存储消息)
  6.基本工作原理
DSC0000.png

   客户端(生产者) send Message -->Exchange (交换机通过不同的类型将消息保存到对应的queue)-->Queue  
   客户端(消费者)通过订阅来消费queue中的消息。
  以上基础概念整理来源于 RabbitMQ基础概念详细介绍
在Windows系统中安装RabbitMQ
  1. 下载安装erlang (我用的是otp_win64_19.3版本)  
  下载地址 http://www.erlang.org/downloads(根据操作系统选择32还64位)  
  2. 下载安装rabbitmq-server(我用的是rabbitmq-server-3.6.10版本)
  下载地址 http://www.rabbitmq.com/install-windows.html
  安装好后,在看装目录下看到
DSC0001.png

  接下来用启用DOS命令
  a. cd 到sbin目录下,我的安装目录是D:\RabbitMQServer\rabbitmq_server-3.6.10\sbin, 输入D: 回车,cd  RabbitMQServer\rabbitmq_server-3.6.10\sbin
DSC0002.png

  b. 查看安装是否成功命令 :rabbitmqctl status
DSC0003.png

  c.安装管理插件命令:rabbitmq-plugins enable rabbitmq_management
   DSC0004.png
  安装成功,在浏览器中输入 http://127.0.0.1:15672/
DSC0005.png

  输入来宾账号 guest 密码 guest ,成功登陆进来,是不是有点小激动。
DSC0006.png

  guest 账号是管理员账号,可以添加Exchanges,Queues,Admin。但我们一般不使用guest账号,继续用命令来添加账号和权限。
  d:添加用户:rabbitmqctl.bat add_user username password
DSC0007.png

  e:添加“超级管理员”角色: rabbitmqctl.bat set_user_tags username administrator
DSC0008.png

DSC0009.png

  mymq账号也是超级管理员了,Can access virtual hosts :No access ,可以看到还没有能够访问的虚拟机,接下来添加虚拟机。
  f: 添加虚拟机:  rabbitmqctl add_vhost vhostName
DSC00010.png

DSC00011.png

  myvhost虚拟机并没有Users,接下来给虚拟机绑定账号。
  g:定虚拟机和用户权限:rabbitmqctl set_permissions -p 虚拟机名称 账户名 ".*" ".*" ".*"
DSC00012.png

  h:处于习惯我一般删除掉guest账号:rabbitmqctl.bat delete_user username
  好了,重新登陆管理页面,一切正常,接下来开始实战了。
EasyNetQ的基本使用
项目中安装EasyNetQ
DSC00013.png

DSC00014.png

  EasyNetQ是依赖于RabbitMQ.Client的,所以会被一并安装到项目中。
Publish发布消息
DSC00015.png

DSC00016.png

  Model有个Queue的特性,定义Queue名称和Exchange名称。然后直接用Publish方法把Msg通过Model指定的交换机推送到指定队列去。
  运行代码,看看MQ的管理页面。
DSC00017.png

  已经创建了Model指定的交换机TestQueue.Exchange, Type:topic , Features:D 。D:Durable 说明默认创建的交换机是持久化的。
  因为还没有订阅消息,所以在Queues中还看不到对应的队列。
Subscribe订阅消息
DSC00018.png

  为什么要在订阅代码上套一个while(true)了? 是为了把控制台程序模拟成Windows服务,因为控制台程序运行一闪而过,没办法真正订阅到MQ的消息。
  实际开发中,一般用Topself来把控制台程序发布成Windows服务,后面有时间再写一篇关于Topself的学习博客。
  再重复刚才的Publish操作,测试下整个流程。
DSC00019.png

自定义Topic
DSC00020.png

  这样消息会被发送到名称为Test.开头的所有Queue队列中。
SendReceive
  通过send和receive可以将消息发送到指定队列。
   DSC00021.png
   DSC00022.png
DSC00023.png

  本文博客园地址:http://www.cnblogs.com/struggle999/p/6937530.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-390286-1-1.html 上篇帖子: RabbitMQ入门_08_所谓的点对点与发布订阅模型 下篇帖子: RabbitMQ-从基础到实战(4)— 消息的交换(中)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表