RabbitMQ介绍3 - 运行和管理RabbitMQ
2016-02-16 15:50
169 查看
安装。官方介绍:http://www.rabbitmq.com/download.html。一般产品环境会部署到Linux环境,但做为简单尝试,可以部署到Windows上(这里是部署介绍:http://www.rabbitmq.com/install-windows.html )。
查看系统状态。可以使用rabbitmqctl命令查看,或者使用Web管理页面。启用web管理功能的命令:rabbitmq-plugins enable rabbitmq_management。默认管理界面访问地址: http://server-name:15672/, 默认用户名guest,密码guest。
查看日志。如果安装在Windows系统,服务的日志在目录%APPDATA%\RabbitMQ\log下(Linux为/var/log/rabbitmq/),日志文件为.log]rabbit@[hostname].log,其它日志在文件-sasl.log]rabbit@[hostname]-sasl.log。这两个日志有什么区别呢?SASL(System Application Support Libraries,系统应用程序支持库)是库的集合,作为Erlang-OTP发行版的一部分,它帮助开发者在开发Erlang应用的时候,提供一系列标准,其中之一是日志记录格式。所以,当Rabbitmq记录Erlang相关信息时,会记入sasl的日志中,例如无法启动Rabbitmq节点的信息。 除了查看日志文件,RabbitMQ还提供了一个topic类型Exchange叫做amq.rabbitmq.log,rabbitmq会按照error、warning、info的routing key发送消息,可以绑定queue到这里接收实时的日志消息。
配置文件。配置文件路径:Windows系统为%APPDATA%\RabbitMQ\rabbitmq.config,Linux为/etc/rabbitmq/rabbitmq.config。关于配置选项的解释: http://www.rabbitmq.com/configure.html#config-items。下面是一个配置文件例子。Rabbitmq的配置文件是一个包含了嵌套哈希表的数值。哈希表以“[”开始,以“]”结束,其中的每个键值对格式为“{[option_name],[option_value]}”,[option_value]可以是一个hash表。
1) [
2) {mnesia, [{dump_log_write_threshold, 1000}]},
3) {rabbit, [{vm_memory_high_watermark, 0.4}]}
4) ].
服务器管理。RabbitMQ使用Erlang编写的,类似于Jave,Erlang也提供了虚拟机,Erlang天生就能让应用程序无需知道是否在同一台机器上即可互相通信,这让RabbitMQ的集群和消息路由变得简单。多个应用可以运行在同一个节点,应用可以跨节点调用,就像本地调用一样。如果应用崩溃了,节点会尝试重启应用。下面的“RabbitMQ节点”,如无特别说明,指的是rabbitmq所在的Erlang节点。
RabbitMQ节点管理命令。
用户管理命令。
权限管理。从1.6.0版本开始,RabbitMQ实现了一套ACL风格的权限系统。分为读、写、配置权限。
命令设置例子,设置用户cashing-tier在vhost sycamore上的权限。
$ ./rabbitmqctl set_permissions -p sycamore -s all cashing-tier ".\*" ".\*" ".\*"
Setting permissions for user "cashing-tier" in vhost "sycamore" ...
...done.
查看系统状态。可以使用rabbitmqctl命令查看,或者使用Web管理页面。启用web管理功能的命令:rabbitmq-plugins enable rabbitmq_management。默认管理界面访问地址: http://server-name:15672/, 默认用户名guest,密码guest。
查看日志。如果安装在Windows系统,服务的日志在目录%APPDATA%\RabbitMQ\log下(Linux为/var/log/rabbitmq/),日志文件为.log]rabbit@[hostname].log,其它日志在文件-sasl.log]rabbit@[hostname]-sasl.log。这两个日志有什么区别呢?SASL(System Application Support Libraries,系统应用程序支持库)是库的集合,作为Erlang-OTP发行版的一部分,它帮助开发者在开发Erlang应用的时候,提供一系列标准,其中之一是日志记录格式。所以,当Rabbitmq记录Erlang相关信息时,会记入sasl的日志中,例如无法启动Rabbitmq节点的信息。 除了查看日志文件,RabbitMQ还提供了一个topic类型Exchange叫做amq.rabbitmq.log,rabbitmq会按照error、warning、info的routing key发送消息,可以绑定queue到这里接收实时的日志消息。
配置文件。配置文件路径:Windows系统为%APPDATA%\RabbitMQ\rabbitmq.config,Linux为/etc/rabbitmq/rabbitmq.config。关于配置选项的解释: http://www.rabbitmq.com/configure.html#config-items。下面是一个配置文件例子。Rabbitmq的配置文件是一个包含了嵌套哈希表的数值。哈希表以“[”开始,以“]”结束,其中的每个键值对格式为“{[option_name],[option_value]}”,[option_value]可以是一个hash表。
1) [
2) {mnesia, [{dump_log_write_threshold, 1000}]},
3) {rabbit, [{vm_memory_high_watermark, 0.4}]}
4) ].
服务器管理。RabbitMQ使用Erlang编写的,类似于Jave,Erlang也提供了虚拟机,Erlang天生就能让应用程序无需知道是否在同一台机器上即可互相通信,这让RabbitMQ的集群和消息路由变得简单。多个应用可以运行在同一个节点,应用可以跨节点调用,就像本地调用一样。如果应用崩溃了,节点会尝试重启应用。下面的“RabbitMQ节点”,如无特别说明,指的是rabbitmq所在的Erlang节点。
RabbitMQ节点管理命令。
命令 | 说明 |
Rabbitmq-server | 启动服务 |
Rabbitmqctl status | 查看服务状态 |
Rabbitmqctl stop | 停止服务,包括Erlang的运行环境。注意没有Rabbitmqctl start来启动服务,只能用Rabbitmq-server。 |
Rabbitmqctl stop_app | 停止服务,不会停掉Erlang运行环境。 |
Rabbitmqctl start_app | 启动服务,用于上面的停止服务情况。 |
命令 | 说明 |
Rabbitmqctl add_user username password | 创建用户 |
Rabbitmqctl delete_user username | 删除用户 |
Rabbitmqctl list_users | 列出所有用户 |
Rabbitmqctl change_password username password | 修改密码 |
AMQP命令 | 配置 | 写 | 读 |
exchange.declare | exchange | ||
exchange.delete | exchange | ||
queue.declare | Queue | ||
queue.delete | Queue | ||
queue.bind | queue | exchange | |
basic.publish | exchange | ||
basic.get | queue | ||
basic.consume | queue | ||
queue.purge | queue |
命令设置例子,设置用户cashing-tier在vhost sycamore上的权限。
$ ./rabbitmqctl set_permissions -p sycamore -s all cashing-tier ".\*" ".\*" ".\*"
Setting permissions for user "cashing-tier" in vhost "sycamore" ...
...done.
相关文章推荐
- windows MS-MPI 的使用
- Android xml中为文字添加阴影(shadow方法)
- (八)外观模式
- hdu 3371 Connect the Cities【MST】
- 做好性能测试需要了解的知识汇总
- docker attch退出
- Android手机调整/data分区和/sdcard分区
- JS闭包
- DataTable.select(string filterExpression)的注意事项
- 获取当前时间。。
- No Spring WebApplicationInitializer types detected on classpath
- JAVA Hibernate工作原理及为什么要用
- 69道java Spring面试题和答案
- Mobile开发之meta篇
- java随机数生成(固定位数)
- Java-day01常识及环境
- linux_for_each_entry
- Mysql中MyISAM、InnoDB两种表类型的区别
- 常用的JS页面跳转代码调用大全
- php刷新当前页面