日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

RabbitMQ管理(4)——应用管理

發(fā)布時(shí)間:2024/4/11 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 RabbitMQ管理(4)——应用管理 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

歡迎支持筆者新作:《深入理解Kafka:核心設(shè)計(jì)與實(shí)踐原理》和《RabbitMQ實(shí)戰(zhàn)指南》,同時(shí)歡迎關(guān)注筆者的微信公眾號:朱小廝的博客。

歡迎跳轉(zhuǎn)到本文的原文鏈接:https://honeypps.com/mq/rabbitmq-management-of-app-management/


本文主要闡述應(yīng)用與集群相關(guān)的一些操作管理命令,包括關(guān)閉、重置、開啟服務(wù),還有建立集群的一些信息。有關(guān)集群搭建更多的信息可以參考RabbitMQ的安裝及集群搭建方法。

rabbitmqctl stop [pid_file]
用于停止運(yùn)行RabbitMQ的Erlang虛擬機(jī)和RabbitMQ服務(wù)應(yīng)用。如果指定了pid_file,還需要等待指定進(jìn)程的結(jié)束。其中pid_file是通過調(diào)用rabbitmq-server啟動RabbitMQ服務(wù)時(shí)創(chuàng)建的,默認(rèn)情況下存放于Mnesia目錄中,可以通過RABBITMQ_PID_FILE這個環(huán)境變量來改變存放路徑。注意,如果是rabbitmq-server –detach啟動的RabbitMQ服務(wù)則不會生成pid_file這個文件。

示例如下:

[root@node1 ~]# rabbitmqctl stop /opt/rabbitmq/var/lib/rabbitmq/mnesia/rabbit\@node1.pid Stopping and halting node rabbit@node1 [root@node1 ~]# rabbitmqctl stop Stopping and halting node rabbit@node1

rabbitmqctl shutdown
用于停止運(yùn)行RabbitMQ的Erlang虛擬機(jī)和RabbitMQ服務(wù)應(yīng)用。執(zhí)行這個命令會阻塞直到Erlang虛擬機(jī)進(jìn)程的退出。如果RabbitMQ沒有成功關(guān)閉,則會返回一個非零值。這個命令和rabbitmqctl stop的不同的是,它不需要指定pid_file而可以阻塞等待指定進(jìn)程的關(guān)閉。

示例如下:

[root@node1 ~]# rabbitmqctl shutdown Shutting down RabbitMQ node rabbit@node1 running at PID 1706 Waiting for PID 1706 to terminate RabbitMQ node rabbit@node1 running at PID 1706 successfully shut down

rabbitmqctl stop_app
停止RabbitMQ服務(wù)應(yīng)用,但是Erlang虛擬機(jī)還是處于運(yùn)行狀態(tài)。此命令優(yōu)先執(zhí)行其他管理操作(這些管理操作需要先停止RabbitMQ應(yīng)用),比如rabbitmqctl reset。

示例如下:

[root@node1 ~]# rabbitmqctl stop_app Stopping rabbit application on node rabbit@node1

rabbitmqctl start_app
啟動RabbitMQ應(yīng)用。此命令典型的用途是在執(zhí)行了其他管理操作之后,重新啟動之前停止的RabbitMQ應(yīng)用,譬如rabbitmqctl reset。

示例如下:

[root@node1 ~]# rabbitmqctl start_app Starting node rabbit@node1

rabbitmqctl wait [pid_file]
等待RabbitMQ應(yīng)用的啟動。它會等到pid_file的創(chuàng)建,然后等待pid_file中的所代表的進(jìn)程啟動。當(dāng)指定的進(jìn)程沒有啟動RabbitMQ應(yīng)用而關(guān)閉時(shí)將會返回失敗。

示例如下:

[root@node1 ~]# rabbitmqctl wait /opt/rabbitmq/var/lib/rabbitmq/mnesia/rabbit\@node1.pid Waiting for rabbit@node1 pid is 3468 [root@node1 ~]# rabbitmqctl wait /opt/rabbitmq/var/lib/rabbitmq/mnesia/rabbit\@node1.pid Waiting for rabbit@node1 pid is 3468 Error: process_not_running

rabbitmqctl reset
將RabbitMQ節(jié)點(diǎn)重置還原到最初狀態(tài),包括從原所在的集群中刪除此節(jié)點(diǎn),從管理數(shù)據(jù)庫中刪除所有的配置數(shù)據(jù),如已配置的用戶、vhost等,以及刪除所有的持久化消息。執(zhí)行rabbitmqctl reset命令前必須停止RabbitMQ應(yīng)用(比如先執(zhí)行rabbitmqctl stop_app)。

示例如下:

[root@node1 ~]# rabbitmqctl stop_app Stopping rabbit application on node rabbit@node1 [root@node1 ~]# rabbitmqctl reset Resetting node rabbit@node1

rabbitmqctl force_reset
強(qiáng)制將RabbitMQ節(jié)點(diǎn)重置還原到最初狀態(tài)。不同于rabbitmqctl reset,rabbitmqctl force_reset命令不論當(dāng)前管理數(shù)據(jù)庫的狀態(tài)和集群配置是什么,會無條件地重置節(jié)點(diǎn)。它只能在數(shù)據(jù)庫或集群配置已損壞的情況下才可使用。與rabbitmqctl reset命令一下,執(zhí)行rabbitmqctl force_reset命令前必須先停止RabbitMQ應(yīng)用。

示例如下:

[root@node1 ~]# rabbitmqctl stop_app Stopping rabbit application on node rabbit@node1 [root@node1 ~]# rabbitmqctl force_reset Forcefully resetting node rabbit@node1

rabbitmqctl rotate_logs {suffix}
指示RabbitMQ節(jié)點(diǎn)輪換日志文件。RabbitMQ節(jié)點(diǎn)會將原來的日志文件中的內(nèi)容追加到“原始名稱+后綴”的日志文件中,然后再將新的日志內(nèi)容記錄到新創(chuàng)建的日志中(與原日志文件同名)。當(dāng)目標(biāo)文件不存在時(shí),將會重新創(chuàng)建。如果不指定suffix,那么則日志文件只是重新打開而不會進(jìn)行輪換。

示例如下所示,原日志文件為rabbit@node1.log和rabbit@node1-sasl.log,輪換日志之后,原日志文件中的內(nèi)容就被追加到rabbit@node1.log.1和 rabbit@node1-sasl.log.1日志中,之后重新建立rabbit@node1.log和rabbit@node1-sasl.log文件用來接收新的日志。

[root@node1 rabbitmq]# pwd /opt/rabbitmq/var/log/rabbitmq [root@node1 rabbitmq]# ll -rw-r--r-- 1 root root 1024127 Aug 18 11:56 rabbit@node1.log -rw-r--r-- 1 root root 720553 Aug 17 19:16 rabbit@node1-sasl.log [root@node1 rabbitmq]# rabbitmqctl rotate_logs .1 Rotating logs to files with suffix ".1" [root@node1 rabbitmq]# ll -rw-r--r-- 1 root root 0 Aug 18 12:05 rabbit@node1.log -rw-r--r-- 1 root root 1024202 Aug 18 12:05 rabbit@node1.log.1 -rw-r--r-- 1 root root 0 Aug 18 12:05 rabbit@node1-sasl.log -rw-r--r-- 1 root root 720553 Aug 18 12:05 rabbit@node1-sasl.log.1

rabbitmqctl hipe_compile {directory}
將部分RabbitMQ代碼用HiPE(HiPE是指High Performance Erlang ,是Erlang版的JIT)編譯,并且將編譯后的.beam文件(beam文件是Erlang編譯器生成的文件格式,可以直接加載到Erlang虛擬機(jī)中運(yùn)行的文件格式)保存到指定的文件目錄中。如果這個目錄不存在則會自行創(chuàng)建。如果這個目錄中原本有任何.beam文件,則會在執(zhí)行編譯前被刪除。如果要使用預(yù)編譯的這些文件,需要設(shè)置RABBITMQ_SERVER_CODE_PATH這個環(huán)境變量來指定hipe_compile調(diào)用的路徑。

示例如下:

[root@node1 rabbitmq]# rabbitmqctl hipe_compile /opt/rabbitmq/tmp/rabbit-hipe/ebin HiPE compiling: |---------------------------------------------------------||#########################################################| Compiled 57 modules in 55s [root@node1 rabbitmq]# ls /opt/rabbitmq/tmp/rabbit-hipe/ebin array.beam proplists.beam rabbit_misc.beam credit_flow.beam qlc.beam rabbit_msg_file.beam delegate.beam queue.beam rabbit_msg_store.beam dict.beam rabbit_amqqueue.beam rabbit_msg_store_ets_index.beam file_handle_cache.beam rabbit_amqqueue_process.beam rabbit_net.beam gb_sets.beam rabbit_basic.beam rabbit_queue_index.beam gb_trees.beam rabbit_binary_generator.beam rabbit_reader.beam gen.beam rabbit_binary_parser.beam rabbit_router.beam gen_fsm.beam rabbit_channel.beam rabbit_trace.beam gen_server2.beam rabbit_command_assembler.beam rabbit_variable_queue.beam lists.beam rabbit_event.beam rabbit_writer.beam lqueue.beam rabbit_exchange.beam rpc.beam mnesia.beam rabbit_exchange_decorator.beam sets.beam mnesia_lib.beam rabbit_exchange_type_direct.beam sofs.beam mnesia_tm.beam rabbit_exchange_type_fanout.beam ssl.beam orddict.beam rabbit_exchange_type_topic.beam ssl_connection.beam ordsets.beam rabbit_framing_amqp_0_9_1.beam ssl_record.beam pmon.beam rabbit_guid.beam tls_connection.beam priority_queue.beam rabbit_limiter.beam tls_record.beam

歡迎跳轉(zhuǎn)到本文的原文鏈接:https://honeypps.com/mq/rabbitmq-management-of-app-management/


歡迎支持筆者新作:《深入理解Kafka:核心設(shè)計(jì)與實(shí)踐原理》和《RabbitMQ實(shí)戰(zhàn)指南》,同時(shí)歡迎關(guān)注筆者的微信公眾號:朱小廝的博客。


總結(jié)

以上是生活随笔為你收集整理的RabbitMQ管理(4)——应用管理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。