ホームページ  >  記事  >  php教程  >  用PHP 写的基于 Memcache 的 Queue

用PHP 写的基于 Memcache 的 Queue

PHP中文网
PHP中文网オリジナル
2016-05-25 17:12:39880ブラウズ

PHP代码

 <?php  
    class MQ{  
        public static $client;  
        private static $m_real;  
        private static $m_front;  
        private static $m_data = array();  
        const QUEUE_MAX_NUM = 100000000;  
        const QUEUE_FRONT_KEY = &#39;_queue_item_front&#39;;  
        const QUEUE_REAL_KEY = &#39;_queue_item_real&#39;;  
        public static function setupMq($conf) {  
            self::$client = memcache_pconnect($conf);  
            self::$m_real = memcache_get(self::$client, self::QUEUE_REAL_KEY);  
            self::$m_front = memcache_get(self::$client, self::QUEUE_FRONT_KEY);  
            if (!isset(self::$m_real) || emptyempty(self::$m_real)) {  
                self::$real= 0;  
            }  
            if (!isset(self::$m_front) || emptyempty(self::$m_front)) {  
                self::$m_front = 0;  
            }  
            return self::$client;  
        }  
        public static function add($queue, $data) {  
            $result = false;  
            if (self::$m_real < self::QUEUE_MAX_NUM) {  
                if (memcache_add(self::$client, $queue.self::$m_real, $data)) {  
                    self::mqRealChange();  
                    $result = true;  
                }  
            }  

            return $result;  
        }  
        public static function get($key, $count) {  
            $num = 0;  
            for ($i=self::$m_front;$i<self::$m_front + $count;$i++) {  
                if ($dataTmp = memcache_get(self::$client, $key.$i)) {  
                    self::$m_data[] = $dataTmp;  
                    memcache_delete(self::$client, $key.$i);  
                    $num++;  
                }  
            }  
            if ($num>0) {  
                self::mqFrontChange($num);  
            }  
            return self::$m_data;  
        }  
        private static function mqRealChange() {  
            memcache_add(self::$client, self::QUEUE_REAL_KEY, 0);  
            self::$m_real = memcache_increment(self::$client, self::QUEUE_REAL_KEY, 1);  
        }  

        private static function mqFrontChange($num) {  
            memcache_add(self::$client, self::QUEUE_FRONT_KEY, 0);  
            self::$m_front = memcache_increment(self::$client, self::QUEUE_FRONT_KEY, $num);  
        }  
        public static function mflush($memcache_obj) {  
            memcache_flush($memcache_obj);  
        }  
        public static function Debug() {  
            echo &#39;real:&#39;.self::$m_real."<br>/r/n";  
            echo &#39;front:&#39;.self::$m_front."<br>/r/n";  
            echo &#39;wait for process data:&#39;.intval(self::$m_real - self::$m_front);  
            echo "<br>/r/n";  
            echo &#39;<pre class="brush:php;toolbar:false">&#39;;  
            print_r(self::$m_data);  
            echo &#39;<pre class="brush:php;toolbar:false">&#39;;  
        }  
    }  
    define(&#39;FLUSH_MQ&#39;,0);//CLEAN ALL DATA  
    define(&#39;IS_ADD&#39;,0);//SET DATA  
    $mobj = MQ::setupMq(&#39;127.0.0.1&#39;,&#39;11211&#39;);  
    if (FLUSH_MQ) {  
        MQ::mflush($mobj);  
    } else {  
        if (IS_ADD) {  
            MQ::add(&#39;user_sync&#39;, &#39;1test&#39;);  
            MQ::add(&#39;user_sync&#39;, &#39;2test&#39;);  
            MQ::add(&#39;user_sync&#39;, &#39;3test&#39;);  
            MQ::add(&#39;user_sync&#39;, &#39;4test&#39;);  
            MQ::add(&#39;user_sync&#39;, &#39;5test&#39;);  
            MQ::add(&#39;user_sync&#39;, &#39;6test&#39;);  
        } else {  
            MQ::get(&#39;user_sync&#39;, 10);  
        }  

    }  
    MQ::Debug();  ?>

使用方法

MQ::setupMq(&#39;127.0.0.1&#39;,&#39;11211&#39;);//连接

MQ::add($key, $value);//添加数据到队列

MQ::add($key, $value);//添加数据到队列

MQ::add($key, $value);//添加数据到队列

MQ::add($key, $value);//添加数据到队列

MQ::add($key, $value);//添加数据到队列

MQ::add($key, $value);//添加数据到队列

MQ:get($key, 10);//取出一定数量的数据


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。