Rabbitmq

初识rabbitmq

RabbitMQ是流行的开源消息队列系统,用erlang语言开发。RabbitMQ是AMQP(高级消息队列协议)的标准实现。假设不熟悉AMQP,直接看RabbitMQ的文档会比較困难。只是它也仅仅有几个关键概念,这里简介

几个概念说明:

Broker:简单来说就是消息队列server实体。

Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

Queue:消息队列载体,每一个消息都会被投入到一个或多个队列。

Binding:绑定,它的作用就是把exchange和queue依照路由规则绑定起来。

Routing Key:路由keyword,exchange依据这个keyword进行消息投递。

vhost:虚拟主机,一个broker里能够开设多个vhost,用作不同用户的权限分离。

producer:消息生产者,就是投递消息的程序。

consumer:消息消费者,就是接受消息的程序。

channel:消息通道,在client的每一个连接里,可建立多个channel,每一个channel代表一个会话任务。

由Exchange,Queue,RoutingKey三个才干决定一个从Exchange到Queue的唯一的线路。

消息队列的使用过程大概例如以下:

)client连接到消息队列server,打开一个channel。

)client声明一个exchange,并设置相关属性。

)client声明一个queue,并设置相关属性。

)client使用routing key,在exchange和queue之间建立好绑定关系。

)client投递消息到exchange。

exchange接收到消息后,就依据消息的key和已经设置的binding,进行消息路由,将消息投递到一个或多个队列里。

exchange也有几个类型,全然依据key进行投递的叫做Direct交换机,比如,绑定时设置了routing
key为”abc”,那么client提交的消息,仅仅有设置了key为”abc”的才会投递到队列。对key进行模式匹配后进行投递的叫做Topic交换机,符号”#”匹配一个或多个词,符号”*”匹配正好一个词。比如”abc.#”匹配”abc.def.ghi”,”abc.*”仅仅匹配”abc.def”。另一种不须要key的,叫做Fanout交换机,它採取广播模式,一个消息进来时,投递到与该交换机绑定的全部队列。

个部分:

)exchange持久化,在声明时指定durable => 1

)queue持久化,在声明时指定durable => 1

是非持久化)

假设exchange和queue都是持久化的,那么它们之间的binding也是持久化的。假设exchange和queue两者之间有一个持久化,一个非持久化,就不同意建立绑定。

安装开发环境和库

1.将文件夹中的librabbitmq.so.1放到文件夹 /usr/local/lib/librabbitmq.so.1

2.安装rabbitm须要的环境和库

yum install -y ncurses-devel

yum install gcc

yum install g++

yum install cmake

yum install make

yum install php

yum install mysql

yum install php-process

yum install php-devel

yum install mysql-server

#安装php的amq支持扩展

wget http://pecl.php.net/get/amqp-1.0.3.tgz

tar zxvf amqp-1.0.3.tgz

cd amqp-1.0.3

/usr/bin/phpize

./configure--with-php-config=/usr/bin/php-config --with-amqp

make && make install

#php.ini 加入

vi /etc/php.ini

extension="amqp.so"

#安装erlang支持

wgethttp://www.erlang.org/download/otp_src_R15B01.tar.gz

tar -zxvf otp_src_R15B01.tar.gz

cd otp_src_R15B01

./configure --prefix=/home/erlang--without-javac

make && make install

ln -s /home/erlang/bin/erl/usr/local/bin/erl

3. 安装rabbitma

解压rabbitmq-server-generic-unix-3.3.4.tar

进入sbin文件夹:

启动rabbitmq服务,运行 nohup./rabbitmq-server start &

启动rabbitmqserver以及命令

当第一次启动服务,检測数据库是否未初始化或者被删除,它会用以下的资源初始化一个新的数据库:

一个命名为 / 的虚拟宿主一个名为guestpassword也为guest的用户,他拥有/虚拟宿主的全部权限假设你的中间件是公开訪问的,最好改动guest用户的password。管理概观rabbitmqctl 是RabbitMQ中间件的一个命令行管理工具。它通过连接一个中间件节点运行全部的动作。本地节点默认被命名为”rabbit”。能够通过这个命令前使用”-n”标志明白的指定节点名称, 比如:# rabbitmqctl -n rabbit@shortstop add_user tonyg changeit

这个命令指示RabbitMQ中间件在rabbit@shortstop 节点创建一个tonyg/changeit的用户。

在一个名为”server.example.com”的主机,RabbitMQ Erlang节点的名称一般是rabbit@server(除非RABBITMQ_NODENAM在中间件启动时候被设置)。hostnam -s 的输出一般是”@”符号正确的后缀。rabbitmqctl 默认产生具体输出。通过”-q”标示可选择安静模式。rabbitmqctl -q status应用和集群管理1.停止RabbitMQ应用,关闭节点

# rabbitmqctl stop

2.停止RabbitMQ应用

# rabbitmqctl stop_app

3.启动RabbitMQ应用

# rabbitmqctl start_app

4.显示RabbitMQ中间件各种信息

# rabbitmqctl status

5.重置RabbitMQ节点

# rabbitmqctl reset

# rabbitmqctl force_reset

从它属于的不论什么集群中移除,从管理数据库中移除全部数据,比如配置过的用户和虚拟宿主, 删除全部持久化的消息。

force_reset命令和reset的差别是无条件重置节点,无论当前管理数据库状态以及集群的配置。假设数据库或者集群配置错误发生才使用这个最后的手段。

注意:仅仅有在停止RabbitMQ应用后,reset和force_reset才干成功。

6.循环日志文件

# rabbitmqctl rotate_logs[suffix]

7.集群管理

# rabbitmqctl cluster clusternode…

用户管理

1.加入用户

# rabbitmqctl add_user username password

2.删除用户

# rabbitmqctl delete_user username

3.改动password

# rabbitmqctl change_password usernamenewpassword

4.列出全部用户

# rabbitmqctl list_users

权限控制1.创建虚拟主机

# rabbitmqctl add_vhost vhostpath

2.删除虚拟主机

# rabbitmqctl delete_vhost vhostpath

3.列出全部虚拟主机

# rabbitmqctl list_vhosts

4.设置用户权限

# rabbitmqctl set_permissions [-pvhostpath] username regexp regexp regexp

5.清除用户权限

# rabbitmqctl clear_permissions [-pvhostpath] username

6.列出虚拟主机上的全部权限

# rabbitmqctl list_permissions [-pvhostpath]

7.列出用户权限

# rabbitmqctl list_user_permissionsusername

样例:

加入  rabbitmqctl add_vhost az

rabbitmqctl set_permissions -p az guest".*" ".*" ".*"

接口描写叙述

amqp_connection_state_tamqp_new_connection(void);

接口说明:声明一个新的amqp connection

intamqp_open_socket(char const *hostname, int portnumber);

接口说明:获取socket.

參数说明:hostname        RabbitMQ server所在主机

portnumber     RabbitMQ server监听端口

voidamqp_set_sockfd(amqp_connection_state_t state,int sockfd);

接口说明:将amqp connection和sockfd进行绑定

amqp_rpc_reply_tamqp_login(amqp_connection_state_t state, char const *vhost,intchannel_max,int frame_max,int heartbeat,amqp_sasl_method_enum sasl_method,...);

接口说明:用于登录RabbitMQ server,主要目的为了进行权限管理;

參数说明:state    amqpconnection

vhost   rabbit-mq的虚机主机,是rabbit-mq进行权限管理的最小单位

就可以

,增大这个值有助于提高吞吐,减少这个值有利于减少时延

heartbeat

sasl_method  用于SSL鉴权,默认值參考后文demo

amqp_channel_open_ok_t*amqp_channel_open(amqp_connection_state_t state, amqp_channel_t channel);

接口说明:用于关联conn和channel

amqp_exchange_declare_ok_t*amqp_exchange_declare(amqp_connection_state_t state, amqp_channel_t channel,amqp_bytes_t exchange, amqp_bytes_t type, amqp_boolean_t passive,amqp_boolean_t durable, amqp_table_t
arguments);

接口说明:声明declare

參数说明:state

channel

exchange

type     "fanout" "direct" "topic"三选一

passive

curable

arguments

amqp_queue_declare_ok_t*amqp_queue_declare(amqp_connection_state_t state, amqp_channel_t channel,amqp_bytes_t queue, amqp_boolean_t passive, amqp_boolean_t durable,amqp_boolean_t exclusive, amqp_boolean_t
auto_delete, amqp_table_targuments);

接口说明:声明queue

參数说明:state   amqp connection

channel

queue  queue name

passive

durable  队列是否持久化

exclusive  当前连接不在时,队列是否自己主动删除

aoto_delete
没有consumer时,队列是否自己主动删除

arguments
用于拓展參数,比方x-ha-policy用于mirrored queue

amqp_queue_bind_ok_t*amqp_queue_bind(amqp_connection_state_t state, amqp_channel_t channel,amqp_bytes_t queue, amqp_bytes_t exchange, amqp_bytes_t routing_key, amqp_table_t arguments);

接口说明:声明binding

amqp_basic_qos_ok_t*amqp_basic_qos(amqp_connection_state_t state, amqp_channel_t channel, uint32_tprefetch_size, uint16_t prefetch_count, amqp_boolean_t global);

接口说明:qos是 quality of service,我们这里使用主要用于控制预取消息数,避免消息按条数均匀分配,须要和no_ack配合使用

參数说明:state

channel

prefetch_size
为unlimited

prefetch_count
预取的消息条数

global

amqp_basic_consume_ok_t*amqp_basic_consume(amqp_connection_state_t state, amqp_channel_t channel,amqp_bytes_t queue, amqp_bytes_t consumer_tag, amqp_boolean_t no_local,amqp_boolean_t no_ack, amqp_boolean_t
exclusive, amqp_table_t arguments);

接口说明:開始一个queue consumer

參数说明:state

channel

queue

consumer_tag

no_local

no_ack    是否须要确认消息后再从队列中删除消息

exclusive

arguments

int amqp_basic_ack(amqp_connection_state_tstate,amqp_channel_t channel,uint64_t delivery_tag,amqp_boolean_t multiple);

intamqp_basic_publish(amqp_connection_state_t state,amqp_channel_tchannel,amqp_bytes_t exchange,amqp_bytes_t routing_key,amqp_boolean_tmandatory,amqp_boolean_t immediate,struct amqp_basic_properties_t_
const*properties,amqp_bytes_t body);

接口说明:公布消息

參数说明:state

channel

exchange

routing_key  当exchange为默认“”时,此处填写queue_name,当exchange为direct,此处为binding_key

mandatory

immediate
同上

properties
很多其它属性,怎样设置消息持久化,參见文后demo

body
消息体

amqp_rpc_reply_tamqp_channel_close(amqp_connection_state_t state,amqp_channel_t channel,intcode);

amqp_rpc_reply_tamqp_connection_close(amqp_connection_state_t state,int code);

intamqp_destroy_connection(amqp_connection_state_t state);

rabbitmq技术的一些感悟(一)的更多相关文章

  1. RabbitMq 技术文档

    RabbitMq 技术文档 目录 1 AMQP简介 2 AMQP的实现 3 RabbitMQ简介 3.1 概念说明 3.2 消息队列的使用过程 3.3 RabbitMQ的特性 4 RabbitMQ使用 ...

  2. RabbitMQ技术详解(转)

    RabbitMQ是什么 定义 RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python.Ruby..NET.Java.JMS.C.PHP.Action ...

  3. rabbitmq技术

    Rabbitmq 初识rabbitmq RabbitMQ是流行的开源消息队列系统,用erlang语言开发.RabbitMQ是AMQP(高级消息队列协议)的标准实现.如果不熟悉AMQP,直接看Rabbi ...

  4. 关于当前Web前端技术的一些感悟和笔记

    最近这些年,随着前端应用技术突飞猛进,产生了很多新的前端框架,当然也引入了数不胜数的前端技术概念,前端不在是早期Web Form的拖拉处理方式,也不再是Ajax+HTML那么简单,随着前端技术的发展, ...

  5. C#多线程技术提高RabbitMQ消费吞吐率

    一.课程介绍 本次分享课程属于<C#高级编程实战技能开发宝典课程系列>中的第二部分,阿笨后续会计划将实际项目中的一些比较实用的关于C#高级编程的技巧分享出来给大家进行学习,不断的收集.整理 ...

  6. RabbitMQ的简单应用

    虽然后台使用了读写分离技术,能够在一定程度上抗击高并发,但是如果并发量特别巨大时,主数据库不能同时处理高并发的请求,这时数据库容易宕机. 问题: 现在的问题是如何既能保证数据库正常运行,又能实现用户数 ...

  7. RabbitMQ安装笔记

    前言 项目中某些场景考虑到高并发情况,调研后决定使用RabbitMQ,本来以为很简单,没想到配置环境花费了好多时间,按照网上的方法来,总是有其他问题需要继续查找,特记录此笔记,方便下次部署安装. 本笔 ...

  8. C# RabbitMQ优先级队列实战项目演练

    一.需求背景 当用户在商城上进行下单支付,针对客户等级的不同和订单金额的大小划分客户级别,需要优先处理给标识为大订单的客户发送一份订单邮件提醒.那么我们应用程序如何解决这样的需求场景呢?今天阿笨给大家 ...

  9. C# RabbitMQ延迟队列功能实战项目演练

    一.需求背景 当用户在商城上进行下单支付,我们假设如果8小时没有进行支付,那么就后台自动对该笔交易的状态修改为订单关闭取消,同时给用户发送一份邮件提醒.那么我们应用程序如何实现这样的需求场景呢?在之前 ...

随机推荐

  1. 一个简单的HTTP服务器(多线程)

    为了更好的了解HTTP协议, 特意谢了一个简单HTTP服务器, 代码只有400行. 因为很简单, 所以效率也不怎么高, 而且支持的特性也不多, 不过也可以运行, 性能跟Apache差不多. ===== ...

  2. AS3.0下去除flash右键菜单

    这两天工作中遇到一个问题,就是网页中内嵌的flash小游戏的用户体验,当鼠标在flash上点击右键时,出现的右键菜单中会有播放,停止等选项,虽然不会造成什么漏洞,但是体验非常差.在寻找解决方案的时候, ...

  3. 讨论asp.net通过机器cookie仿百度(google)实现搜索input搜索提示弹出框自己主动

    为实现自己主动弹出通过用户输入关键词相关的搜索结果,在这里,我举两个解决方案,对于两个不同的方案. 常用的方法是建立一个用户数据库中查找关系表.然后输入用户搜索框keyword异步调用数据表中的相关数 ...

  4. 京东评论情感分类器(基于bag-of-words模型)

    京东评论情感分类器(基于bag-of-words模型) 近期在本来在研究paraVector模型,想拿bag-of-words来做对照. 数据集是京东的评论,经过人工挑选,选出一批正面和负面的评论. ...

  5. windows phone (26) ApplicationBar应用程序栏

    原文:windows phone (26) ApplicationBar应用程序栏 在应用程序中,如果需要几个按钮或者菜单来执行一些普通的命令,就应该考虑使用ApplicationBar,因为silv ...

  6. erlang集群IP及port管理

    erlang集群是依靠epmd维护的,epmd是erlang集群节点间port映射的守护进程.负责维护集群内的节点连接.提供节点名称到IP地址及port的解析服务. epmd 自己定义port号 ep ...

  7. Debug with Eclipse

    In this post we are going to see how to develop applications using Eclipse and Portofino 4. The trad ...

  8. 三种方法让你的Service不被“一键加速”和系统杀掉

    基本上大家都知道提高service优先级能够在非常大程度上让你的service免于由于内存不足而被kill,当然系统仅仅是在此时先把优先级低的kill掉,假设内存还是不够,也会把你的service干掉 ...

  9. MessageBox()功能

    MessageBox()功能.这是一个非常频繁使用的Win32 API,在屏幕上显示一个窗体,提出问题,并等待用户输入.它的原型是 int MessageBox(HWND hwnd,LPCTSTR l ...

  10. iOS 8 新特性

    这篇文章会介绍iOS8开发相关的主要特性. App 插件 通过支持插件,iOS8让我们可以系统指定的区域进行扩展,也就是为用户的特定需求提供自定义的方法.例如:可以通过App插件帮助用户分享他们的内容 ...