zoukankan      html  css  js  c++  java
  • 在PHP中如何使用消息列队

    /**
     * 消息列队服务
     * @author zhou.tingze
     * @example
     * -----------------------------------Create----------------------------------------
     * $array = array('a','b','c','d');
     * $this->load->library('amqp_service');
     * $this->amqp_service->setSaveType('test_exchange', 'test_queue', 'test_router');
     * $this->amqp_service->createMessageQueue($array);
     * -----------------------------------End-------------------------------------------
     * 
     * -----------------------------------Get-------------------------------------------
     * $this->load->library('amqp_service');
     * $this->amqp_service->setSaveType('test_exchange', 'test_queue', 'test_router');
     * $message_queue = $this->amqp_service->getMessageQueue();
     * var_dump($message_queue)
     * -----------------------------------End-------------------------------------------
     */
    
    class Amqp_service extends Base_service{
    	
    	public $conn;
    	public $exchange;
    	public $queue;
    	public $router;
    	
        function __construct(){
            parent:: __construct();
            
            //获取系统配置
            $this->load->config('app_config', TRUE);
            $app_config = $this->config->item('app_config');
    
            $this->connect($app_config['amqp']);
        }
        
        /**
         * 
         * 尝试连接Amqp服务
         */
        private function connect($amqp_args)
        {	
        	$this->conn = new AMQPConnection($amqp_args);
    		$this->conn->connect();
    		
    		if (!$this->conn->isConnected()) 
    		{
    			throw new Exception('Cannot connect to the broker.');
    		}
        }
        
        /**
         * 
         * 设定消息列队保存方式
         * @param String $exchange_name 交换机名
         * @param String $queue_name    消息列队名
         * @param String $router_name   路由名
         */
        public function setSaveType($exchange_name, $queue_name, $router_name)
        {
        	$this->exchange = $exchange_name;
        	$this->queue    = $queue_name;
        	$this->router   = $router_name;
        }
        
        /**
         * 
         * 创建消息列队
         * @param Array $array
         */
        public function createMessageQueue($array)
        {
        	//创建交换机 
    		$channel = new AMQPChannel($this->conn);
    		$ex      = new AMQPExchange($channel);
    		
    		//交换机名 
    		$ex->setName($this->exchange);
    		$ex->setType(AMQP_EX_TYPE_DIRECT);
    		$ex->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
    		$ex->declare();
    		
    		//创建消息列队
    		$q = new AMQPQueue($channel);
    		
    		//队列名
    		$q->setName($this->queue);
    		$q->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
    		$q->declare();
    		
    		//绑定交换机与队列,并指定路由键 
    		$q->bind($this->exchange, $this->router);
    		
    		//消息发布
    		$channel->startTransaction();
    		$message = json_encode($array);
    		$ex->publish($message, $this->router);
    		$channel->commitTransaction();
    		
    		//$this->conn->disconnect();
        }
        
        /**
         * 
         * 获取消息列队
         */
        public function getMessageQueue()
        {
        	try
        	{
    	    	//设置queue名称,使用exchange,绑定routingkey
    			$channel = new AMQPChannel($this->conn);
    			$q       = new AMQPQueue($channel);
    			
    			$q->setName($this->queue);
    			$q->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
    			$q->declare();
    			$q->bind($this->exchange, $this->router);   
    			
    			//消息获取
    			$messages = $q->get(AMQP_AUTOACK) ;
    			
    			$arr = array();
    			if ($messages){
    				$arr = json_decode($messages->getBody(), true );
    			}
        	}catch (Exception $e){
        		throw new Exception($e->getMessage());
        	}
    		//$this->conn->disconnect();
    		
    		return $arr;
        }
        
        /*
        public function getAllMessageQueue()
        {
    		//设置queue名称,使用exchange,绑定routingkey
    		$channel = new AMQPChannel($this->conn);
    		$q       = new AMQPQueue($channel);
    		
    		$q->setName($this->queue);
    		$q->setFlags(AMQP_DURABLE | AMQP_AUTODELETE);
    		$q->declare();
    		$q->bind($this->exchange, $this->router);   
    		$this->conn->disconnect();
    		
    		//阻塞模式获取消息列队
    		while(True){ 
    		    $q->consume('processMessage');   
    		    //$q->consume('processMessage', AMQP_AUTOACK); //自动ACK应答  
    		} 
        }
        */
        
        public function __destruct()
        {
        	$this->conn->disconnect();
        }
    }
    
    
    /**
     * 消费回调函数
     * 处理消息
     * @param Object $envelope
     * @param Object $queue
     */ 
    /*
    function processMessage($envelope, $queue) { 
        $msg = $envelope->getBody(); 
        echo $msg . '<br />';
        
        //手动发送ACK应答 
        $queue->ack($envelope->getDeliveryTag()); 
    } 
    */
    

      

  • 相关阅读:
    Unreal Engine 4官网教程
    快速上手制作暗黑类游戏动作打击感的一些要点
    充分利用 UE4 中的噪声
    综合帖:多角度闲聊游戏打击感
    鹅厂内部分享:七步教你从无到有做数值
    二叉树、二叉搜索树、平衡二叉树、B树、B+树的精确定义和区别探究
    MySQL的InnoDB索引原理详解
    分布式核心
    Mysql 原理以及常见mysql 索引等
    redis核心原理
  • 原文地址:https://www.cnblogs.com/adtuu/p/4670229.html
Copyright © 2011-2022 走看看