高并发rabbitmq队列的安装使用

准备工作
一台服务器:Ubuntu Server 16.04.1 LTS 64位

安装RabbitMq
可以参照RabbitMq官网的安装教程(Ihttps://www.rabbitmq.com/install-debian.html),来进行安装。
这里我们使用apt-get来安装,就简单的几条命令:

1.由于rabbitMq需要erlang语言的支持,在安装rabbitMq之前需要安装erlang,执行命令:

apt-get install erlang-nox     # 安装erlang


erl    # 查看relang语言版本,成功执行则说明relang安装成功

2.添加公钥

wget -O- https://www.rabbitmq.com/rabbitmq-release-signing-key.asc | sudo apt-key add -

3.更新软件包

apt-get update

4.安装 RabbitMQ

apt-get install rabbitmq-server  #安装成功自动启动

5.查看 RabbitMq状态

systemctl status rabbitmq-server   #Active: active (running) 说明处于运行状态

# service rabbitmq-server status 用service指令也可以查看,同systemctl指令

6.启动、停止、重启

service rabbitmq-server start    # 启动
service rabbitmq-server stop     # 停止
service rabbitmq-server restart  # 重启 

执行了上面的步骤,rabbitMq已经安装成功。

7.启用 web端可视化操作界面,我们还需要配置Management Plugin插件

rabbitmq-plugins enable rabbitmq_management   # 启用插件
service rabbitmq-server restart    # 重启

此时,应该可以通过 http://localhost:15672 查看,使用默认账户guest/guest 登录。
注意:RabbitMQ 3.3 及后续版本,guest 只能在服务本机登录。
瞄了一眼官方文档,说的是默认会创建guest用户,但是只能服务器本机登录,建议创建其他新用户,授权,用来做其他操作。


8.查看用户

rabbitmqctl list_users

9.添加管理用户

rabbitmqctl add_user admin yourpassword   # 增加普通用户
rabbitmqctl set_user_tags admin administrator    # 给普通用户分配管理员角色 
ok,你可以在你的浏览器上输入:http://服务器Ip:15672/ 来访问你的rabbitmq监控页面。使用刚刚添加的新用户登录。

 

接下来你就可以配置 Virtual host ,exchange,queue了

PHP 操作rabbitmq类RabbitMQCommand.php

<?php
/*
 * amqp协议操作类,可以访问rabbitMQ
 * 需先安装php_amqp扩展
 */
class RabbitMQCommand{

    public $configs = array();
    //交换机名称
    public $exchange_name = '';
    //队列名称
    public $queue_name = '';
    //路由名称
    public $route_key = '';
    /*
     * 持久化,默认True
     */
    public $durable = True;
    /*
     * 自动删除
     * exchange is deleted when all queues have finished using it
     * queue is deleted when last consumer unsubscribes
     * 
     */
    public $autodelete = False;
    /*
     * 镜像
     * 镜像队列,打开后消息会在节点之间复制,有master和slave的概念
     */
    public $mirror = False;
    
    private $_conn = Null;
    private $_exchange = Null;
    private $_channel = Null;
    private $_queue = Null;

    /*
     * @configs array('host'=>$host,'port'=>5672,'username'=>$username,'password'=>$password,'vhost'=>'/')
     */

    public function __construct($configs = array(), $exchange_name = '', $queue_name = '', $route_key = '') {
        $this->setConfigs($configs);
        $this->exchange_name = $exchange_name;
        $this->queue_name = $queue_name;
        $this->route_key = $route_key;
    }
    
    private function setConfigs($configs) {
        if (!is_array($configs)) {
            throw new Exception('configs is not array');
        }
        if (!($configs['host'] && $configs['port'] && $configs['username'] && $configs['password'])) {
            throw new Exception('configs is empty');
        }
        if (empty($configs['vhost'])) {
            $configs['vhost'] = '/';
        }
        $configs['login'] = $configs['username'];
        unset($configs['username']);
        $this->configs = $configs;
    }

    /*
     * 设置是否持久化,默认为True
     */

    public function setDurable($durable) {
        $this->durable = $durable;
    }

    /*
     * 设置是否自动删除
     */

    public function setAutoDelete($autodelete) {
        $this->autodelete = $autodelete;
    }
    /*
     * 设置是否镜像
     */
    public function setMirror($mirror) {
        $this->mirror = $mirror;
    }

    /*
     * 打开amqp连接
     */

    private function open() {
        if (!$this->_conn) {
            try {
                $this->_conn = new AMQPConnection($this->configs);
                
                $this->_conn->connect();
                
                $this->initConnection();
            } catch (AMQPConnectionException $ex) {
                
                throw new Exception('cannot connection rabbitmq',500);
            }
        }
    }

    /*
     * rabbitmq连接不变
     * 重置交换机,队列,路由等配置
     */

    public function reset($exchange_name, $queue_name, $route_key) {
        $this->exchange_name = $exchange_name;
        $this->queue_name = $queue_name;
        $this->route_key = $route_key;
        $this->initConnection();
    }

    /*
     * 初始化rabbit连接的相关配置
     */

    private function initConnection() {
        if (empty($this->exchange_name) || empty($this->queue_name) || empty($this->route_key)) {
            throw new Exception('rabbitmq exchange_name or queue_name or route_key is empty',500);
        }
        $this->_channel = new AMQPChannel($this->_conn);
        $this->_exchange = new AMQPExchange($this->_channel);
        $this->_exchange->setName($this->exchange_name);

        $this->_exchange->setType(AMQP_EX_TYPE_DIRECT);
        if ($this->durable)
            $this->_exchange->setFlags(AMQP_DURABLE);
        if ($this->autodelete)
            $this->_exchange->setFlags(AMQP_AUTODELETE);
        $this->_exchange->declare();

        $this->_queue = new AMQPQueue($this->_channel);
        $this->_queue->setName($this->queue_name);
        if ($this->durable)
            $this->_queue->setFlags(AMQP_DURABLE);
        if ($this->autodelete)
            $this->_queue->setFlags(AMQP_AUTODELETE);
        if ($this->mirror) 
            $this->_queue->setArgument('x-ha-policy', 'all');
        $this->_queue->declare();
        
        $this->_queue->bind($this->exchange_name, $this->route_key);
    }

    public function close() {
        if ($this->_conn) {
            $this->_conn->disconnect();
        }
    }
    
    public function __sleep() {
        $this->close();
        return array_keys(get_object_vars($this));
    }

    public function __destruct() {
        $this->close();
    }
    
    /*
     * 生产者发送消息
     */
    public function send($msg) {
        $this->open();
        if(is_array($msg)){
            $msg = json_encode($msg);
        }else{
            $msg = trim(strval($msg));
        }
        return $this->_exchange->publish($msg, $this->route_key);
    }
    /*
     * 消费者
     * $fun_name = array($classobj,$function) or function name string
     * $autoack 是否自动应答
     * 
     * function processMessage($envelope, $queue) {
            $msg = $envelope->getBody(); 
            echo $msg."\n"; //处理消息
            $queue->ack($envelope->getDeliveryTag());//手动应答
        }
     */
    public function run($fun_name, $autoack = True){
        $this->open();
        if (!$fun_name || !$this->_queue) return False;  
        while(True){
            if ($autoack) $this->_queue->consume($fun_name, AMQP_AUTOACK);   
            else $this->_queue->consume($fun_name);    
        }
    }

}

php 生产端 send.php

set_time_limit(0);
include_once('RabbitMQCommand.php');
 
$configs = array('host'=>'192.168.206.128','port'=>5672,'username'=>'mytest','password'=>'mytest','vhost'=>'/');
$exchange_name = 'class-e-1';
$queue_name = 'class-q-1';
$route_key = 'class-r-1';
$ra = new RabbitMQCommand($configs,$exchange_name,$queue_name,$route_key);
$ra->durable = true;
for($i=0;$i<=10;$i++){
    $ra->send(json_encode(['date'=>date('Y-m-d H:i:s',time()),'type'=>1,'name'=>rand(1,233).'nice']));
}
exit();

php消费类consumer.php

<?php
error_reporting(0);
include_once('RabbitMQCommand.php');

$configs = array('host'=>'192.168.206.128','port'=>5672,'username'=>'mytest','password'=>'mytest','vhost'=>'/');
$exchange_name = 'class-e-1';
$queue_name = 'class-q-1';
$route_key = 'class-r-1';
$ra = new RabbitMQCommand($configs,$exchange_name,$queue_name,$route_key);

class A{
    function processMessage($envelope, $queue) {
        $msg = $envelope->getBody();
        //处理网站业务
        $envelopeID = $envelope->getDeliveryTag();
        
        //$queue->ack($envelopeID);
        
        $pid = posix_getpid();
       
        file_put_contents("/app/bossadmin/log{$pid}.log", $msg.'|'.$envelopeID.''."\r\n",FILE_APPEND);
        echo 56;
        $queue->ack($envelopeID);
    }
}
$a = new A();

$s = $ra->run(array($a,'processMessage'),false);

接下来就按照网站的业务来处理消费队列了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章