백엔드 개발 PHP 튜토리얼 php操作redies打包的类

php操作redies打包的类

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

php操作redies封装的类


<?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_sn; ++$i){                    $this->_linkHandle['slave'][$i]->close();                }            break;            // 关闭所有            case 1:                $this->getRedis()->close();                for($i=0; $i_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 _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;$igetRedis()->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 Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

화웨이 GT3 Pro와 GT4의 차이점은 무엇입니까? 화웨이 GT3 Pro와 GT4의 차이점은 무엇입니까? Dec 29, 2023 pm 02:27 PM

많은 사용자들이 스마트 시계를 선택할 때 Huawei 브랜드를 선택하게 됩니다. 그 중 Huawei 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에서 ID란 무엇입니까? SQL에서 ID는 자동 증가 숫자를 생성하는 데 사용되는 특수 데이터 유형으로, 테이블의 각 데이터 행을 고유하게 식별하는 데 사용됩니다. ID 열은 일반적으로 기본 키 열과 함께 사용되어 각 레코드에 고유한 식별자가 있는지 확인합니다. 이 문서에서는 Identity를 사용하는 방법과 몇 가지 실제 코드 예제를 자세히 설명합니다. Identity를 사용하는 기본 방법은 테이블을 생성할 때 Identit을 사용하는 것입니다.

SpringBoot가 Redis 키 변경 이벤트를 모니터링하는 방법 SpringBoot가 Redis 키 변경 이벤트를 모니터링하는 방법 May 26, 2023 pm 01:55 PM

1. 기능 개요 키스페이스 알림을 통해 클라이언트는 채널이나 패턴을 구독하여 어떤 방식으로든 Rediskey 변경 사항을 수정하는 이벤트를 수신할 수 있습니다. 키 키를 수정하는 모든 명령입니다. LPUSHkeyvalue[value…] 명령을 수신한 모든 키입니다. db 데이터베이스의 모든 만료된 키입니다. 이벤트는 Redis의 구독 및 게시 기능(pub/sub)을 통해 배포되므로 구독 및 게시 기능을 지원하는 모든 클라이언트는 아무런 수정 없이 바로 키스페이스 알림 기능을 사용할 수 있습니다. Redis의 현재 구독 및 게시 기능은 Fireandforget 전략을 채택하고 있기 때문에 프로그램이

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;}}}# 출력 위 코드의 출력은 간단히 결론을 내릴 수 있습니다. return은 finally 전에 실행됩니다. 바이트코드 수준에서 무슨 일이 일어나는지 살펴보겠습니다. 다음은 case1 메소드의 바이트코드 일부를 가로채서 소스 코드를 비교하여 각 명령어의 의미를 주석으로 표시합니다.

수정: Windows 11에서 캡처 도구가 작동하지 않음 수정: Windows 11에서 캡처 도구가 작동하지 않음 Aug 24, 2023 am 09:48 AM

Windows 11에서 캡처 도구가 작동하지 않는 이유 문제의 근본 원인을 이해하면 올바른 솔루션을 찾는 데 도움이 될 수 있습니다. 캡처 도구가 제대로 작동하지 않는 주요 이유는 다음과 같습니다. 초점 도우미가 켜져 있습니다. 이렇게 하면 캡처 도구가 열리지 않습니다. 손상된 응용 프로그램: 캡처 도구가 실행 시 충돌하는 경우 응용 프로그램이 손상되었을 수 있습니다. 오래된 그래픽 드라이버: 호환되지 않는 드라이버가 캡처 도구를 방해할 수 있습니다. 다른 응용 프로그램의 간섭: 실행 중인 다른 응용 프로그램이 캡처 도구와 충돌할 수 있습니다. 인증서가 만료되었습니다. 업그레이드 프로세스 중 오류로 인해 이 문제가 발생할 수 있습니다. 이 문제는 대부분의 사용자에게 적합하며 특별한 기술 지식이 필요하지 않습니다. 1. Windows 및 Microsoft Store 앱 업데이트

Redis에서 키 값 일괄 삭제 문제를 해결하는 방법 Redis에서 키 값 일괄 삭제 문제를 해결하는 방법 May 31, 2023 am 08:59 AM

발생한 문제: 개발 과정에서 login_logID(ID는 변수)와 같은 특정 규칙에 따라 일괄 삭제해야 하는 키가 발생합니다. 이제 "login_log*"와 같은 데이터를 삭제해야 하지만 그 자체는 redis입니다. 클래스 키 값에 대한 명령 키만 있고 특정 클래스에 대한 일괄 삭제 명령은 없습니다. 해결 방법: 먼저 쿼리한 다음 삭제하고, xargs를 사용하여 매개변수를 전달하고(xargs는 파이프 또는 표준 입력(stdin) 데이터를 명령줄 매개변수로 변환할 수 있음) 쿼리 문을 먼저 실행한 다음 쿼리된 키 값과 원래 del 매개변수를 제거합니다. 삭제. redis-cliKEYSkey* (검색 조건)|xargsr

패치가 불가능한 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 장치의 보안이 손상되었습니다. Infineon SLB96xx 시리즈 TPM을 사용하는 Feitian A22 JavaCard 및 기타 장치도 취약합니다.

See all articles