RabbitMQ服務安裝配置

  RabbitMQ是流行的開源消息隊列系統,是AMQP(Advanced Message Queuing Protocol高級消息隊列協議)的標準實現,用erlang語言開發。RabbitMQ聽說具備良好的性能和時效性,同時還可以很是好的支持集羣和負載部署,很是適合在較大規模的分佈式系統中使用,具體特性還在驗證中,待檢驗。因爲項目須要,安裝並配置了RabbitMQ,服務器操做系統是CentOS7,服務器是阿里雲主機。具體步驟以下:node

  安裝依賴文件:linux

  yum install gcc glibc-devel make ncurses-devel openssl-devel xmltoweb

  1.Erlang安裝配置shell

  下載安裝包,地址http://www.erlang.org/downloads,我選擇的是otp_src_18.3.tar.gz。服務器

  而後解壓文件:app

[root@iZ25e3bt9a6Z rabbitmq]# tar -xzvf otp_src_18.3.tar.gz
[root@iZ25e3bt9a6Z rabbitmq]# cd otp_src_18.3/

  配置安裝路徑編譯代碼:socket

[root@iZ25e3bt9a6Z otp_src_18.3]# ./configure --prefix=/opt/erlang

  執行編譯結果:async

[root@iZ25e3bt9a6Z otp_src_18.3]# make && make install

  完成後進入/opt/erlang查看執行結果分佈式

[root@iZ25e3bt9a6Z rabbitmq]# cd /opt/erlang/
[root@iZ25e3bt9a6Z erlang]# erl
Erlang/OTP 18 [erts-7.3] [source] [64-bit] [smp:8:8] [async-threads:10] [hipe] [kernel-poll:false]

Eshell V7.3  (abort with ^G)
1> 

  當出現以上信息時表示安裝完成。而後輸入’halt().’退出便可。性能

  而後在配置Erlang環境變量,vi /etc/profile文件,增長下面的環境變量:

#set erlang environment
export PATH
=$PATH:/opt/erlang/bin

  source  /etc/profile使得文件生效

  在安裝Erlang過程當中,可能會遇到如下問題,通常都是由於系統中缺乏相應的包引發的,缺乏什麼包直接yum安裝便可。

  2.下載安裝RabbitMq

[root@iZ25e3bt9a6Z rabbitmq]# weget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.1/rabbitmq-server-generic-unix-3.6.1.tar.xz

  解壓文件

[root@iZ25e3bt9a6Z rabbitmq]# xz -d rabbitmq-server-generic-unix-3.6.1.tar.xz
[root@iZ25e3bt9a6Z rabbitmq]# tar -xvf rabbitmq-server-generic-unix-3.6.1.tar  -C /opt

  解壓後進入文件夾/opt發現多了個文件夾rabbitmq-server-generic-unix-3.6.1 ,重命名爲rabbitmq以便記憶。

  而後在配置rabbitmq環境變量,vi /etc/profile文件,增長下面的環境變量:

#set rabbitmq environment
export PATH=$PATH:/opt/rabbitmq/sbin

  source  /etc/profile使得文件生效

  3.RabbitMQ服務啓動關閉

  以上就已經完成了RabbitMq的安裝,怎麼啓動服務呢?

  啓動服務:

[root@iZ25e3bt9a6Z rabbitmq]# cd sbin/
[root@iZ25e3bt9a6Z sbin]# ./rabbitmq-server -detached

  查看服務狀態:

[root@iZ25e3bt9a6Z sbin]# ./rabbitmqctl status
Status of node rabbit@iZ25e3bt9a6Z ...
[{pid,11849},
 {running_applications,
     [{rabbitmq_management,"RabbitMQ Management Console","3.6.1"},
      {rabbitmq_management_agent,"RabbitMQ Management Agent","3.6.1"},
      {rabbitmq_web_dispatch,"RabbitMQ Web Dispatcher","3.6.1"},
      {webmachine,"webmachine","1.10.3"},
      {amqp_client,"RabbitMQ AMQP Client","3.6.1"},
      {mochiweb,"MochiMedia Web Server","2.13.0"},
      {syntax_tools,"Syntax tools","1.7"},
      {ssl,"Erlang/OTP SSL application","7.3"},
      {public_key,"Public key infrastructure","1.1.1"},
      {asn1,"The Erlang ASN1 compiler version 4.0.2","4.0.2"},
      {crypto,"CRYPTO","3.6.3"},
      {compiler,"ERTS  CXC 138 10","6.0.3"},
      {inets,"INETS  CXC 138 49","6.2"},
      {rabbit,"RabbitMQ","3.6.1"},
      {mnesia,"MNESIA  CXC 138 12","4.13.3"},
      {rabbit_common,[],"3.6.1"},
      {xmerl,"XML parser","1.3.10"},
      {os_mon,"CPO  CXC 138 46","2.4"},
      {ranch,"Socket acceptor pool for TCP protocols.","1.2.1"},
      {sasl,"SASL  CXC 138 11","2.7"},
      {stdlib,"ERTS  CXC 138 10","2.8"},
      {kernel,"ERTS  CXC 138 10","4.2"}]},
 {os,{unix,linux}},
 {erlang_version,
     "Erlang/OTP 18 [erts-7.3] [source] [64-bit] [smp:8:8] [async-threads:64] [hipe] [kernel-poll:true]\n"},
 {memory,
     [{total,64111264},
      {connection_readers,0},
      {connection_writers,0},
      {connection_channels,0},
      {connection_other,2808},
      {queue_procs,2808},
      {queue_slave_procs,0},
      {plugins,367288},
      {other_proc,19041296},
      {mnesia,61720},
      {mgmt_db,158696},
      {msg_index,47120},
      {other_ets,1372440},
      {binary,128216},
      {code,27368230},
      {atom,992409},
      {other_system,14568233}]},
 {alarms,[]},
 {listeners,[{clustering,25672,"::"},{amqp,5672,"::"}]},
 {vm_memory_high_watermark,0.4},
 {vm_memory_limit,6556241100},
 {disk_free_limit,50000000},
 {disk_free,37431123968},
 {file_descriptors,
     [{total_limit,65435},
      {total_used,2},
      {sockets_limit,58889},
      {sockets_used,0}]},
 {processes,[{limit,1048576},{used,204}]},
 {run_queue,0},
 {uptime,412681},
 {kernel,{net_ticktime,60}}]

  關閉服務:

[root@iZ25e3bt9a6Z sbin]# ./rabbitmqctl stop
Stopping and halting node rabbit@iZ25e3bt9a6Z ...

  4. 配置網頁插件

  首先建立目錄,不然可能報錯:

mkdir /etc/rabbitmq 

  而後啓用插件:

./rabbitmq-plugins enable rabbitmq_management 

  配置linux 端口 15672 網頁管理  5672 AMQP端口
  而後訪問http://localhost:15672便可 

  默認用戶guest 密碼guest

  

  5. 遠程訪問配置

  默認網頁是不容許訪問的,須要增長一個用戶修改一下權限,代碼以下:

  添加用戶:rabbitmqctl add_user hxb hxb

  添加權限:rabbitmqctl set_permissions -p "/" hxb ".*" ".*" ".*"

      修改用戶角色rabbitmqctl set_user_tags hxb administrator

  而後就能夠遠程訪問了,而後可直接配置用戶權限等信息。

  

  6. rabbitmq經常使用命令

  add_user        <UserName> <Password>

  delete_user     <UserName>

  change_password <UserName> <NewPassword>

  list_users

  add_vhost    <VHostPath>

  delete_vhost <VHostPath>

  list_vhostsset_permissions   [-p <VHostPath>] <UserName> <Regexp> <Regexp> <Regexp>

  clear_permissions [-p <VHostPath>] <UserName>

  list_permissions  [-p <VHostPath>]

  list_user_permissions <UserName>

  list_queues    [-p <VHostPath>] [<QueueInfoItem> ...]

  list_exchanges [-p <VHostPath>] [<ExchangeInfoItem> ...]

  list_bindings  [-p <VHostPath>]

  list_connections [<ConnectionInfoItem> ...]

相關文章
相關標籤/搜索