ホームページ バックエンド開発 PHPチュートリアル PHPはrediesパッケージ化されたクラスを操作します

PHPはrediesパッケージ化されたクラスを操作します

Jun 13, 2016 pm 12:19 PM
gt key return this

PHP はカプセル化されたクラス


<?php/** * Redis 操作,支持 Master/Slave 的负载集群 * * @author jackluo */class RedisCluster{           // 是否使用 M/S 的读写集群方案    private $_isUseCluster = false;           // Slave 句柄标记    private $_sn = 0;           // 服务器连接句柄    private $_linkHandle = array(        &#39;master&#39;=>null,// 只支持一台 Master        'slave'=>array(),// 可以有多台 Slave    );           /**     * 构造函数     *     * @param boolean $isUseCluster 是否采用 M/S 方案     */    public function __construct($isUseCluster=false){        $this->_isUseCluster = $isUseCluster;    }           /**     * 连接服务器,注意:这里使用长连接,提高效率,但不会自动关闭     *     * @param array $config Redis服务器配置     * @param boolean $isMaster 当前添加的服务器是否为 Master 服务器     * @return boolean     */    public function connect($config=array('host'=>'127.0.0.1','port'=>6379), $isMaster=true){        // default port        if(!isset($config['port'])){            $config['port'] = 6379;        }        // 设置 Master 连接        if($isMaster){            $this->_linkHandle['master'] = new Redis();            $ret = $this->_linkHandle['master']->pconnect($config['host'],$config['port']);        }else{            // 多个 Slave 连接            $this->_linkHandle['slave'][$this->_sn] = new Redis();            $ret = $this->_linkHandle['slave'][$this->_sn]->pconnect($config['host'],$config['port']);            ++$this->_sn;        }        return $ret;    }           /**     * 关闭连接     *     * @param int $flag 关闭选择 0:关闭 Master 1:关闭 Slave 2:关闭所有     * @return boolean     */    public function close($flag=2){        switch($flag){            // 关闭 Master            case 0:                $this->getRedis()->close();            break;            // 关闭 Slave            case 1:                for($i=0; $i<$this->_sn; ++$i){                    $this->_linkHandle['slave'][$i]->close();                }            break;            // 关闭所有            case 1:                $this->getRedis()->close();                for($i=0; $i<$this->_sn; ++$i){                    $this->_linkHandle['slave'][$i]->close();                }            break;        }        return true;    }           /**     * 得到 Redis 原始对象可以有更多的操作     *     * @param boolean $isMaster 返回服务器的类型 true:返回Master false:返回Slave     * @param boolean $slaveOne 返回的Slave选择 true:负载均衡随机返回一个Slave选择 false:返回所有的Slave选择     * @return redis object     */    public function getRedis($isMaster=true,$slaveOne=true){        // 只返回 Master        if($isMaster){            return $this->_linkHandle['master'];        }else{            return $slaveOne ? $this->_getSlaveRedis() : $this->_linkHandle['slave'];        }    }           /**     * 写缓存     *     * @param string $key 组存KEY     * @param string $value 缓存值     * @param int $expire 过期时间, 0:表示无过期时间     */    public function set($key, $value, $expire=0){        // 永不超时        if($expire == 0){            $ret = $this->getRedis()->set($key, $value);        }else{            $ret = $this->getRedis()->setex($key, $expire, $value);        }        return $ret;    }           /**     * 读缓存     *     * @param string $key 缓存KEY,支持一次取多个 $key = array('key1','key2')     * @return string || boolean  失败返回 false, 成功返回字符串     */    public function get($key){        // 是否一次取多个值        $func = is_array($key) ? 'mGet' : 'get';        // 没有使用M/S        if(! $this->_isUseCluster){            return $this->getRedis()->{$func}($key);        }        // 使用了 M/S        return $this->_getSlaveRedis()->{$func}($key);    }     /*    // magic function    public function __call($name,$arguments){        return call_user_func($name,$arguments);        }*/    /**     * 条件形式设置缓存,如果 key 不存时就设置,存在时设置失败     *     * @param string $key 缓存KEY     * @param string $value 缓存值     * @return boolean     */    public function setnx($key, $value){        return $this->getRedis()->setnx($key, $value);    }           /**     * 删除缓存     *     * @param string || array $key 缓存KEY,支持单个健:"key1" 或多个健:array('key1','key2')     * @return int 删除的健的数量     */    public function remove($key){        // $key => "key1" || array('key1','key2')        return $this->getRedis()->delete($key);    }           /**     * 值加加操作,类似 ++$i ,如果 key 不存在时自动设置为 0 后进行加加操作     *     * @param string $key 缓存KEY     * @param int $default 操作时的默认值     * @return int 操作后的值     */    public function incr($key,$default=1){        if($default == 1){            return $this->getRedis()->incr($key);        }else{            return $this->getRedis()->incrBy($key, $default);        }    }           /**     * 值减减操作,类似 --$i ,如果 key 不存在时自动设置为 0 后进行减减操作     *     * @param string $key 缓存KEY     * @param int $default 操作时的默认值     * @return int 操作后的值     */    public function decr($key,$default=1){        if($default == 1){            return $this->getRedis()->decr($key);        }else{            return $this->getRedis()->decrBy($key, $default);        }    }           /**     * 添空当前数据库     *     * @return boolean     */    public function clear(){        return $this->getRedis()->flushDB();    }           /* =================== 以下私有方法 =================== */           /**     * 随机 HASH 得到 Redis Slave 服务器句柄     *     * @return redis object     */    private function _getSlaveRedis(){        // 就一台 Slave 机直接返回        if($this->_sn <= 1){            return $this->_linkHandle['slave'][0];        }        // 随机 Hash 得到 Slave 的句柄        $hash = $this->_hashId(mt_rand(), $this->_sn);        return $this->_linkHandle['slave'][$hash];    }           /**     * 根据ID得到 hash 后 0~m-1 之间的值     *     * @param string $id     * @param int $m     * @return int     */    private function _hashId($id,$m=10)    {        //把字符串K转换为 0~m-1 之间的一个值作为对应记录的散列地址        $k = md5($id);        $l = strlen($k);        $b = bin2hex($k);        $h = 0;        for($i=0;$i<$l;$i++)        {            //相加模式HASH            $h += substr($b,$i*2,2);        }        $hash = ($h*1)%$m;        return $hash;    }    /**     *    lpush     */    public function lpush($key,$value){        return $this->getRedis()->lpush($key,$value);    }    /**     *    add lpop     */    public function lpop($key){        return $this->getRedis()->lpop($key);    }    /**     * lrange     */    public function lrange($key,$start,$end){        return $this->getRedis()->lrange($key,$start,$end);        }    /**     *    set hash opeation     */    public function hset($name,$key,$value){        if(is_array($value)){            return $this->getRedis()->hset($name,$key,serialize($value));            }        return $this->getRedis()->hset($name,$key,$value);    }    /**     *    get hash opeation     */    public function hget($name,$key = null,$serialize=true){        if($key){            $row = $this->getRedis()->hget($name,$key);            if($row && $serialize){                unserialize($row);            }            return $row;        }        return $this->getRedis()->hgetAll($name);    }    /**     *    delete hash opeation     */    public function hdel($name,$key = null){        if($key){            return $this->getRedis()->hdel($name,$key);        }        return $this->getRedis()->hdel($name);    }    /**     * Transaction start     */    public function multi(){        return $this->getRedis()->multi();        }    /**     * Transaction send     */    public function exec(){        return $this->getRedis()->exec();        }       }// End Class       // ================= TEST DEMO =================       // 只有一台 Redis 的应用$redis = new RedisCluster();$redis->connect(array('host'=>'127.0.0.1','port'=>6379));//*$cron_id = 10001;$CRON_KEY = 'CRON_LIST'; //$PHONE_KEY = 'PHONE_LIST:'.$cron_id;////cron info$cron = $redis->hget($CRON_KEY,$cron_id);if(empty($cron)){        $cron = array('id'=>10,'name'=>'jackluo');//mysql data    $redis->hset($CRON_KEY,$cron_id,$cron); // set redis    }//phone list$phone_list = $redis->lrange($PHONE_KEY,0,-1);print_r($phone_list);if(empty($phone_list)){    $phone_list =explode(',','13228191831,18608041585');    //mysql data    //join  list    if($phone_list){        $redis->multi();        foreach ($phone_list as $phone) {            $redis->lpush($PHONE_KEY,$phone);                    }        $redis->exec();    }}print_r($phone_list);/*$list = $redis->hget($cron_list,);var_dump($list);*///*///$redis->set('id',35);/*    $redis->lpush('test','1111');    $redis->lpush('test','2222');    $redis->lpush('test','3333');    $list = $redis->lrange('test',0,-1);    print_r($list);    $lpop = $redis->lpop('test');    print_r($lpop);    $lpop = $redis->lpop('test');    print_r($lpop);    $lpop = $redis->lpop('test');    print_r($lpop);*///    var_dump($redis->get('id'));
ログイン後にコピー


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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Huawei GT3 ProとGT4の違いは何ですか? Huawei GT3 ProとGT4の違いは何ですか? Dec 29, 2023 pm 02:27 PM

多くのユーザーはスマートウォッチを選ぶときにファーウェイブランドを選択しますが、その中でもファーウェイ GT3pro と GT4 は非常に人気のある選択肢であり、多くのユーザーはファーウェイ GT3pro と GT4 の違いに興味を持っています。 Huawei GT3pro と GT4 の違いは何ですか? 1. 外観 GT4: 46mm と 41mm、材質はガラスミラー + ステンレススチールボディ + 高解像度ファイバーバックシェルです。 GT3pro: 46.6mm および 42.9mm、材質はサファイアガラス + チタンボディ/セラミックボディ + セラミックバックシェルです。 2. 健全な GT4: 最新の Huawei Truseen5.5+ アルゴリズムを使用すると、結果はより正確になります。 GT3pro: ECG 心電図と血管と安全性を追加

C言語のreturnの使い方を詳しく解説 C言語のreturnの使い方を詳しく解説 Oct 07, 2023 am 10:58 AM

C 言語における return の使い方は、 1. 戻り値の型が void の関数については、return 文を使用して関数の実行を早期に終了することができます; 2. 戻り値の型が void ではない関数については、 return ステートメントは、関数の実行を終了するためのものです。結果は呼び出し元に返されます。 3. 関数の実行を早期に終了します。関数内で return ステートメントを使用して、関数の実行を早期に終了することもできます。関数が値を返さない場合。

SQL の ID 属性は何を意味しますか? SQL の ID 属性は何を意味しますか? Feb 19, 2024 am 11:24 AM

SQL における Identity とは何ですか? 具体的なコード例が必要です。SQL では、Identity は自動インクリメント数値の生成に使用される特別なデータ型です。多くの場合、テーブル内のデータの各行を一意に識別するために使用されます。 Identity 列は、各レコードが一意の識別子を持つようにするために、主キー列と組み合わせてよく使用されます。この記事では、Identity の使用方法といくつかの実用的なコード例について詳しく説明します。 Identity の基本的な使用方法は、テーブルを作成するときに Identity を使用することです。

SpringBoot が Redis キー変更イベントを監視する方法 SpringBoot が Redis キー変更イベントを監視する方法 May 26, 2023 pm 01:55 PM

1. 機能の概要 キースペース通知を使用すると、クライアントはチャネルまたはパターンをサブスクライブすることで、何らかの方法で Rediskey の変更を変更するイベントを受信できます。キーのキーを変更するすべてのコマンド。 LPUSHkeyvalue[value…] コマンドを受信したすべてのキー。 db データベース内の期限切れのキーすべて。イベントは Redis のサブスクリプションおよび公開機能 (pub/sub) を通じて配布されるため、サブスクリプションおよび公開機能をサポートするすべてのクライアントは、変更を加えることなくキースペース通知機能を直接使用できます。 Redis の現在のサブスクリプション機能と公開機能は fireandforget 戦略を採用しているため、プログラムが

修正: Windows 11 で Snipping ツールが機能しない 修正: Windows 11 で Snipping ツールが機能しない Aug 24, 2023 am 09:48 AM

Windows 11 で Snipping Tool が機能しない理由 問題の根本原因を理解すると、適切な解決策を見つけるのに役立ちます。 Snipping Tool が正しく動作しない主な理由は次のとおりです。 フォーカス アシスタントがオンになっている: これにより、Snipping Tool が開かなくなります。破損したアプリケーション: 起動時にスニッピング ツールがクラッシュする場合は、破損している可能性があります。古いグラフィック ドライバー: 互換性のないドライバーは、スニッピング ツールに干渉する可能性があります。他のアプリケーションからの干渉: 実行中の他のアプリケーションが Snipping Tool と競合する可能性があります。証明書の有効期限が切れています: アップグレード プロセス中のエラーにより、この問題が発生する可能性があります。これらの簡単な解決策は、ほとんどのユーザーに適しており、特別な技術知識は必要ありません。 1. Windows および Microsoft Store アプリを更新する

Javaのreturn文とfinally文の実行順序は何ですか? Javaのreturn文とfinally文の実行順序は何ですか? Apr 25, 2023 pm 07:55 PM

ソースコード: publicclassReturnFinallyDemo{publicstaticvoidmain(String[]args){System.out.println(case1());}publicstaticintcase1(){intx;try{x=1;returnx;}finally{x=3;}}}#出力 上記のコードの出力は、単純に次のように結論付けることができます:finally の前に return が実行されます。バイトコード レベルで何が起こるかを見てみましょう。以下は、case1 メソッドのバイトコードの一部をインターセプトし、ソース コードを比較して、各命令の意味に注釈を付けます。

パッチ不可能な Yubico 2 要素認証キーの脆弱性により、ほとんどの Yubikey 5、セキュリティ キー、YubiHSM 2FA デバイスのセキュリティが侵害される パッチ不可能な Yubico 2 要素認証キーの脆弱性により、ほとんどの Yubikey 5、セキュリティ キー、YubiHSM 2FA デバイスのセキュリティが侵害される Sep 04, 2024 pm 06:32 PM

パッチ不可能な Yubico の 2 要素認証キーの脆弱性により、ほとんどの Yubikey 5、セキュリティ キー、および YubiHSM 2FA デバイスのセキュリティが破られています。 Feitian A22 JavaCard および Infineon SLB96xx シリーズ TPM を使用するその他のデバイスも脆弱です。すべて

Redisでキー値が一括削除される問題を解決する方法 Redisでキー値が一括削除される問題を解決する方法 May 31, 2023 am 08:59 AM

発生した問題: 開発プロセス中に、login_logID (ID は変数) など、特定のルールに従ってバッチで削除する必要があるキーが発生します。ここで、「login_log*」などのデータを削除する必要がありますが、redis 自体はバッチクエリのみあり、クラスキー値に対するコマンドキーはありますが、特定のクラスを一括削除するコマンドはありません。解決策: 最初にクエリを実行してから削除し、xargs を使用してパラメータを渡します (xargs はパイプまたは標準入力 (stdin) データをコマンド ライン パラメータに変換できます)。最初にクエリ ステートメントを実行してから、クエリされたキー値と元の del パラメータを削除します。消去。 redis-cliKEYSkey* (検索条件)|xargsr

See all articles