群辉做网站,去掉 wordpress.org,深圳物流公司哪个最便宜,通州网站建设站开发评价PHP使用Redis实战实录系列
PHP使用Redis实战实录1#xff1a;宝塔环境搭建、6379端口配置、Redis服务启动失败解决方案PHP使用Redis实战实录2#xff1a;Redis扩展方法和PHP连接Redis的多种方案PHP使用Redis实战实录3#xff1a;数据类型比较、大小限制和性能扩展PHP使用Re…PHP使用Redis实战实录系列
PHP使用Redis实战实录1宝塔环境搭建、6379端口配置、Redis服务启动失败解决方案PHP使用Redis实战实录2Redis扩展方法和PHP连接Redis的多种方案PHP使用Redis实战实录3数据类型比较、大小限制和性能扩展PHP使用Redis实战实录4单例模式和面向过程操作redis的语法 面向过程操作redis的单例模式 一、单例模式面对对象封装类(1)面对对象封装类(2) 二、面向过程操作Redis1.php连接redis2.共性的运算归类3.Redis服务器操作4.String增删改操作5.List增删改操作6.set增删改操作7.Zset增删改操作8.Hash表结构增删改操作 为了应对不同的场景redis分为是单机模式、主从模式、哨兵模式、集群模式四种模式。 单机模式Standalone Mode单机模式是最基本的 Redis 运行模式它在单个实例上运行不涉及复杂的集群配置。它被广泛用于开发和测试环境。 主从复制模式Master-Slave Replication主从复制模式通过将一个 Redis 实例设为主节点Master和一个或多个 Redis 实例设为从节点Slave实现数据的复制和备份。主节点负责写操作而从节点复制主节点的数据可以用于读操作或故障转移。 哨兵模式Redis Sentinel ModeSentinel 是 Redis 提供的一个高可用解决方案它通过在主从复制模式的基础上添加 Sentinel 进程来实现自动故障检测和故障切换。Sentinel 进程监视主节点和从节点的状态并在主节点故障时自动将从节点升级为主节点。 Cluster 模式Redis Cluster Mode集群模式是 Redis 最常用的分布式解决方案它将多个 Redis 节点组成一个集群每个节点负责存储一部分数据并在节点之间自动进行数据分片和数据迁移。集群模式提供了高扩展性和高可用性。
这些运行模式可以根据需求选择合适的方案来使用 Redis例如在开发和测试环境中使用单机模式生产环境中使用主从复制或集群模式来提供高可用性和横向扩展能力。
一、单例模式
在 PHP 中使用 Redis 的单例模式可以确保在应用程序中只创建一个 Redis 连接实例以便在多个地方共享该连接。
下面是一个简单的示例展示如何使用单例模式实现 Redis 连接
面对对象封装类(1)
class RedisSingleton
{private static $instance;private static $redis;private function __construct(){self::$redis new Redis();self::$redis-connect(127.0.0.1, 6379);// 进行其他 Redis 相关的初始化操作}public static function getInstance(){if (!self::$instance) {self::$instance new RedisSingleton();}return self::$instance;}public function getRedis(){return self::$redis;}
}// 在应用程序中使用 Redis 单例模式
$redisSingleton RedisSingleton::getInstance();
$redis $redisSingleton-getRedis();// 使用 $redis 进行操作例如 $redis-get(key)、$redis-set(key, value) 等面对对象封装类(2)
将redis变量放在配置文件进行整体调用
/** Redis操作类* 单例支持长连接 模式*/class RedisSingleton
{const REDISTIMEOUT 0; //超时private static $_instance []; //类单例数组private $hash;private $redis; //redis连接句柄private function __construct($redis_config []){$this-redis new Redis();$this-hash $redis_config[redis_db];if ($redis_config[redis_pconnect]) {$this-redis-pconnect($redis_config[redis_host], $redis_config[redis_port], self::REDISTIMEOUT);} else {$this-redis-connect($redis_config[redis_host], $redis_config[redis_port], self::REDISTIMEOUT);}//设置连接密码if ($redis_config[redis_auth]) {$this-redis-auth($redis_config[redis_auth]);}//选择库 0-15$this-redis-select($this-hash);}//外部获取实例public static function getInstance($redis_config){if (!isset(self::$_instance[$redis_config[redis_db]])) {self::$_instance[$redis_config[redis_db]] new self($redis_config);}//防止挂掉try {self::$_instance[$redis_config[redis_db]]-Ping() Pong;} catch (Exception $e) {throw new Exception(连接错误);}return self::$_instance[$redis_config[redis_db]];}//获取redis的连接实例public function getRedisConnect(){return $this-redis;}public function __call($method, $args){return call_user_func_array([$this-redis, $method], $args);}/*** 关闭单例时做清理工作*/public function __destruct(){$key $this-hash;$this-redis-close();self::$_instance[$key] null;}private function __clone(){}
}$redis_config [redis_host 127.0.0.1,redis_port 6379,redis_db 0,redis_auth kYABzc8u3zNs7cq,redis_pconnect 0
];$redis RedisSingleton::getInstance($redis_config);
$redis-set(hello, world1);在上述示例中RedisSingleton 类的 getInstance 方法返回一个 Redis 单例实例。当需要使用 Redis 连接时可以调用 getRedis 方法获取该实例的 Redis 连接对象。
通过这种方式无论在应用程序中的哪个位置需要使用 Redis都可以共享同一个 Redis 连接实例避免了重复创建连接的开销。
二、面向过程操作Redis
1.php连接redis
/*1.Connection*/
$redis new Redis();
$redis-connect(127.0.0.1,6379,1);//短链接本地host端口为6379超过1秒放弃链接
$redis-open(127.0.0.1,6379,1);//短链接(同上)
$redis-pconnect(127.0.0.1,6379,1);//长链接本地host端口为6379超过1秒放弃链接
$redis-popen(127.0.0.1,6379,1);//长链接(同上)
$redis-auth(password);//登录验证密码返回【true | false】
$redis-select(0);//选择redis库,0~15 共16个库
$redis-close();//释放资源
$redis-ping(); //检查是否还再链接,[pong]
$redis-ttl(key);//查看失效时间[-1 | timestamps]
$redis-persist(key);//移除失效时间[ 1 | 0]
$redis-sort(key,[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素$array为参数limit等 [array|false]2.共性的运算归类
/*2.共性的运算归类*/
$redis-expire(key,10);//设置失效时间[true | false]
$redis-move(key,15);//把当前库中的key移动到15库中[0|1]
//string
$redis-strlen(key);//获取当前key的长度
$redis-append(key,string);//把string追加到key现有的value中[追加后的个数]
$redis-incr(key);//自增1如不存在key,赋值为1(只对整数有效,存储以10进制64位redis中为str)[new_num | false]
$redis-incrby(key,$num);//自增$num,不存在为赋值,值需为整数[new_num | false]
$redis-decr(key);//自减1[new_num | false]
$redis-decrby(key,$num);//自减$num[ new_num | false]
$redis-setex(key,10,value);//keyvalue有效期为10秒[true]
//list
$redis-llen(key);//返回列表key的长度,不存在key返回0 [ len | 0]
//set
$redis-scard(key);//返回集合key的基数(集合中元素的数量)。[num | 0]
$redis-sMove(key1, key2, member);//移动将member元素从key1集合移动到key2集合。[1 | 0]
//Zset
$redis-zcard(key);//返回集合key的基数(集合中元素的数量)。[num | 0]
$redis-zcount(key,0,-1);//返回有序集key中score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
//hash
$redis-hexists(key,field);//查看hash中是否存在field,[1 | 0]
$redis-hincrby(key,field,$int_num);//为哈希表key中的域field的值加上量(|-)num,[new_num | false]
$redis-hlen(key);//返回哈希表key中域的数量。[ num | 0]
3.Redis服务器操作
/*3.Server*/
$redis-dbSize();//返回当前库中的key的个数
$redis-flushAll();//清空整个redis[总true]
$redis-flushDB();//清空当前redis库[总true]
$redis-save();//同步??把数据存储到磁盘-dump.rdb[true]
$redis-bgsave();//异步把数据存储到磁盘-dump.rdb[true]
$redis-info();//查询当前redis的状态 [verson:2.4.5....]
$redis-lastSave();//上次存储时间key的时间[timestamp]
$redis-watch(key,keyn);//监视一个(或多个) key 如果在事务执行之前这个(或这些) key 被其他命令所改动那么事务将被打断 [true]
$redis-unwatch(key,keyn);//取消监视一个(或多个) key [true]
$redis-multi(Redis::MULTI);//开启事务事务块内的多条命令会按照先后顺序被放进一个队列当中最后由 EXEC 命令在一个原子时间内执行。
$redis-multi(Redis::PIPELINE);//开启管道事务块内的多条命令会按照先后顺序被放进一个队列当中最后由 EXEC 命令在一个原子时间内执行。
$redis-exec();//执行所有事务块内的命令【事务块内所有命令的返回值按命令执行的先后顺序排列当操作被打断时返回空值 false】
4.String增删改操作
/*4.String键值对创建更新同操作*/
$redis-setOption(Redis::OPT_PREFIX,hf_);//设置表前缀为hf_
$redis-set(key,1);//设置keyaa value1 [true]
$redis-mset($arr);//设置一个或多个键值[true]
$redis-setnx(key,value);//keyvalue,key存在返回false[|true]
$redis-get(key);//获取key [value]
$redis-mget($arr);//(string|arr),返回所查询键的值
$redis-del($key_arr);//(string|arr)删除key支持数组批量删除【返回删除个数】
$redis-delete($key_str,$key2,$key3);//删除keys,[del_num]
$redis-getset(old_key,new_value);//先获得key的值然后重新赋值,[old_value | false]
5.List增删改操作
/*5.List栈的结构,注意表头表尾,创建更新分开操作*/
$redis-lpush(key,value);//增只能将一个值value插入到列表key的表头不存在就创建 [列表的长度 |false]
$redis-rpush(key,value);//增只能将一个值value插入到列表key的表尾 [列表的长度 |false]
$redis-lInsert(key, Redis::AFTER, value, new_value);//增将值value插入到列表key当中位于值value之前或之后。[new_len | false]
$redis-lpushx(key,value);//增只能将一个值value插入到列表key的表头不存在不创建 [列表的长度 |false]
$redis-rpushx(key,value);//增只能将一个值value插入到列表key的表尾不存在不创建 [列表的长度 |false]
$redis-lpop(key);//删移除并返回列表key的头元素,[被删元素 | false]
$redis-rpop(key);//删移除并返回列表key的尾元素,[被删元素 | false]
$redis-lrem(key,value,0);//删根据参数count的值移除列表中与参数value相等的元素count(0|-n表头向尾|n表尾向头移除n个value) [被移除的数量 | 0]
$redis-ltrim(key,start,end);//删列表修剪保留(start,end)之间的值 [true|false]
$redis-lset(key,index,new_v);//改从表头数将列表key下标为第index的元素的值为new_v, [true | false]
$redis-lindex(key,index);//查返回列表key中下标为index的元素[value|false]
$redis-lrange(key,0,-1);//查(start,stop|0,-1)返回列表key中指定区间内的元素区间以偏移量start和stop指定。[array|false]
6.set增删改操作 /*6.Set没有重复的member创建更新同操作*/
$redis-sadd(key,value1,value2,valuen);//增改将一个或多个member元素加入到集合key当中已经存在于集合的member元素将被忽略。[insert_num]
$redis-srem(key,value1,value2,valuen);//删移除集合key中的一个或多个member元素不存在的member元素会被忽略 [del_num | false]
$redis-smembers(key);//查返回集合key中的所有成员 [array | ]
$redis-sismember(key,member);//判断member元素是否是集合key的成员 [1 | 0]
$redis-spop(key);//删移除并返回集合中的一个随机元素 [member | false]
$redis-srandmember(key);//查返回集合中的一个随机元素 [member | false]
$redis-sinter(key1,key2,keyn);//查返回所有给定集合的交集 [array | false]
$redis-sunion(key1,key2,keyn);//查返回所有给定集合的并集 [array | false]
$redis-sdiff(key1,key2,keyn);//查返回所有给定集合的差集 [array | false]
7.Zset增删改操作
/*7.Zset没有重复的member有排序顺序,创建更新同操作*/
$redis-zAdd(key,$score1,$member1,$scoreN,$memberN);//增改将一个或多个member元素及其score值加入到有序集key当中。[num | 0]
$redis-zrem(key,member1,membern);//删移除有序集key中的一个或多个成员不存在的成员将被忽略。[del_num | 0]
$redis-zscore(key,member);//查,通过值反拿权 [num | null]
$redis-zrange(key,$start,$stop);//查通过(score从小到大)【排序名次范围】拿member值返回有序集key中【指定区间内】的成员 [array | null]
$redis-zrevrange(key,$start,$stop);//查通过(score从大到小)【排序名次范围】拿member值返回有序集key中【指定区间内】的成员 [array | null]
$redis-zrangebyscore(key,$min,$max[,$config]);//查通过scroe权范围拿member值返回有序集key中指定区间内的(从小到大排)成员[array | null]
$redis-zrevrangebyscore(key,$max,$min[,$config]);//查通过scroe权范围拿member值返回有序集key中指定区间内的(从大到小排)成员[array | null]
$redis-zrank(key,member);//查通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]
$redis-zrevrank(key,member);//查通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]
$redis-ZINTERSTORE();//交集
$redis-ZUNIONSTORE();//差集
8.Hash表结构增删改操作 /*8.Hash表结构创建更新同操作*/
$redis-hset(key,field,value);//增改将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】
$redis-hget(key,field);//查取值【value|false】
$arr array(one1,2,3);$arr2 array(one,0,1);
$redis-hmset(key,$arr);//增改设置多值$arr为(索引|关联)数组,$arr[key]field, [ true ]
$redis-hmget(key,$arr2);//查获取指定下标的field[$arr | false]
$redis-hgetall(key);//查返回哈希表key中的所有域和值。[当key不存在时返回一个空表]
$redis-hkeys(key);//查返回哈希表key中的所有域。[当key不存在时返回一个空表]
$redis-hvals(key);//查返回哈希表key中的所有值。[当key不存在时返回一个空表]
$redis-hdel(key,$arr2);//删删除指定下标的field,不存在的域将被忽略,[num | false]漏刻有时