RabbitMQ 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
set_time_limit(0);
include_once(‘RabbitMQCommand.php‘);

$configs = array(‘host‘=>‘192.168.0.156‘,‘port‘=>5672,‘username‘=>‘xp‘,‘password‘=>‘xp‘,‘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);
for($i=0;$i<=10000000;$i++){
    $ra->send(date(‘Y-m-d H:i:s‘,time()));
}
exit();

  

消费者代码:

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

$configs = array(‘host‘=>‘192.168.0.156‘,‘port‘=>5672,‘username‘=>‘xp‘,‘password‘=>‘xp‘,‘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();
        $pid = posix_getpid();
        file_put_contents("/app/bossadmin/log{$pid}.log", $msg.‘|‘.$envelopeID.‘‘."\r\n",FILE_APPEND);
        $queue->ack($envelopeID);
    }
}
$a = new A();

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

测试结果:

开了6个生产者,6个消费者

TOP:

总结:

RabbitMQ在PHP消费端请求连接后,如果有消息会主动轮询各个消费端,这让php作为守护进程的性能还可以。实际运行较长的时间,cpu内存等数据也都还可以。

而httpsqs需要消费端不断去请求httpsqs服务,守护进程的性能损耗就比较高。

RabbitMQ PHP操作类,守护进程及相关测试数据

时间: 2024-07-31 01:39:52

RabbitMQ PHP操作类,守护进程及相关测试数据的相关文章

linux 创建守护进程的相关知识

linux 创建守护进程的相关知识 http://www.114390.com/article/46410.htm linux 创建守护进程的相关知识,这篇文章主要介绍了linux 创建守护进程的相关知识,需要的朋友可以参考下 关键字:linux.守护进程 创建子进程,父进程退出 这是编写守护进程的第一步.由于守护进程是脱离控制终端的,因此,完成第一步后就会在Shell终端里造成一程序已经运行完毕的假象.之后的所有工作都在子进程中完成,而用户在Shell终端里则可以执行其他命令,从而在形式上做到

Linux守护进程详解(init.d和xinetd)

一 Linux守护进程 Linux 服务器在启动时需要启动很多系统服务,它们向本地和网络用户提供了Linux的系统功能接口,直接面向应用程序和用户.提供这些服务的程序是由运行在后台的守护进程来执行的.守护进程是生存期长的一种进程.它们独立于控制终端并且周期性的执行某种任务或等待处理某些发生的事件.他们常常在系统引导装入时启动,在系统关闭时终止.linux系统有很多守护进程,大多数服务器都是用守护进程实现的.同时,守护进程完成许多系统任务,比如,作 业规划进程crond.打印进程lqd等.有些书籍

Linux守护进程(init.d和xinetd)

一 Linux守护进程 Linux 服务器在启动时需要启动很多系统服务,它们向本地和网络用户提供了Linux的系统功能接口,直接面向应用程序和用户.提供这些服务的程序是由运行在后台 的守护进程来执行的.守护进程是生存期长的一种进程.它们独立于控制终端并且周期性的执行某种任务或等待处理某些发生的事件.他们常常在系统引导装入时启 动,在系统关闭时终止.linux系统有很多守护进程,大多数服务器都是用守护进程实现的.同时,守护进程完成许多系统任务,比如,作 业规划进程crond.打印进程lqd等.有些

linux的守护进程init.d和xinetd.d

Linux 服务器在启动时需要启动很多系统服务,它们向本地和网络用户提供了Linux的系统功能接口,直接面向应用程序和用户.提供这些服务的程序是由运行在后台的守护进程来执行的.守护进程是生存期长的一种进程.它们独立于控制终端并且周期性的执行某种任务或等待处理某些发生的事件.他们常常在系统引导装入时启动,在系统关闭时终止.linux系统有很多守护进程,大多数服务器都是用守护进程实现的.同时,守护进程完成许多系统任务,比如,作 业规划进程crond.打印进程lqd等.有些书籍和资料也把守护进程称作:

Linux 守护进程和超级守护进程(xinetd)

一 .Linux守护进程 Linux 服务器在启动时需要启动很多系统服务,它们向本地和网络用户提供了Linux的系统功能接口,直接面向应用程序和用户.提供这些服务的程序是由运行在后台的守护进程来执行的. 守护进程是生存期长的一种进程.它们独立于控制终端并且周期性的执行某种任务或等待处理某些发生的事件.他们常常在系统引导装入时启动,在系统关闭时终止. linux系统有很多守护进程,大多数服务器都是用守护进程实现的.同时,守护进程完成许多系统任务,比如,作 业规划进程crond.打印进程lqd等.有

创建一个守护进程

一.概述:守护进程也称精灵进程(Daemon),是运行在后台的一种特殊进程.它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件.守护进程是随系统启动而存在,随系统关闭而消失的进程(也就是开机之后就会存在,关机才消失).守护进程是一种很有用的进程,Linux的大多数服务器就是用守护进程实现的. 在终端运行命令:ps axj | head 参数a表示不仅列出当前用户进程,也列出所有其它用户进程. 参数x表示不仅列出有控制终端的进程,也列出所有无控制终端的进程. 参数j表示列出与作业控制

知识回顾、进程的相关知识和操作

1.编程语言的发展: 机器语言:二进制 汇编语言:指令,命令形式的 高级语言:面向过程(C)面向对象(python,c++,java) 2.操作系统的目标: 为了使用户更方便的使用系统 3.计算机的组成: cpu,主板,存储,输入,输出 4.并行.并发 并发:指两件或多件事情,在同一时间间隔内同时执行(宏观上是并行,微观上是串行) 并行:指两件或多件事情,在同一时间间隔内同时执行 5.进程有三部分组成: 代码段,数据段,PCB(进程控制块) 6.进程的三种基本状态: 就绪状态:除了cpu之外,进

处理挂掉的守护进程和其相关信息

在写守护进程的时候,会涉及一些启动锁文件,进程id文件等信息.而当程序一旦挂掉(有时候可能是程序不工作,多线程引起的资源死锁等.),要强制关闭进程并且删除相关的文件信息.手动来操作,比较麻烦.写个程序会比较好: import subprocess,re,sys pidReg = re.compile("root\s+(\d+)\s") def kill(process):     p = subprocess.Popen("ps axu | grep py",she

python全栈脱产第34天------开启进程的两种方式、join方法、进程对象其他相关的属性和方法、僵尸进程、孤儿进程、守护进程、互斥锁

一.开启进程的两种方式 方式一: from multiprocessing import Processimport time def task(name): print('%s is running' %name) time.sleep(3) print('%s is done' %name) # 在windows系统上,开启子进程的操作必须放到if __name__ == '__main__'的子代码中if __name__ == '__main__': p=Process(target=t