redis对象操作setTimeout(),在哪里可以查到用法?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis对象操作setTimeout(),在哪里可以查到用法?相关的知识,希望对你有一定的参考价值。

redis对象操作setTimeout()的用法如下:
setTimeout, expire
设定一个key的活动时间(s)
$redis->setTimeout('x', 3);

有关redis的一系列set操作总结如下:
//SET 集合的相关操作
// sadd 集合添加数据 初始化数据
for($i=0; $i < 10 ; $i++)
$redis->sadd("myset",$i+rand(10,99));

//srem 删除集合中的一个元素
$bool = $redis->srem("myset",16);
echo (int) $bool;
//sMove 将value元素从名称为srckey的集合移到名称为dstkey的集合
$bool = $redis->sMove("myset", "myset1", 35);
echo $bool;
//smembers 显示集合中的元素
$data = $redis->smembers("myset");
// sIsMember, sContains 名称为key的集合中查找是否有value元素,有ture 没有 false
$bool = $redis->sismember("myset",555);
echo (int)$bool;
//scard ssize集合key元素的个数
echo $redis->scard("myset");
//sInterStore
//求交集并将交集保存到output的集合
//$redis->sInterStore('output', 'key1', 'key2', 'key3')
$redis->sinterstore("output","myset","myset1");
$data = $redis->smembers("output");
echo "<pre>";
print_r($data);
// sUnionStore求并集并将并集保存到output的集合
//$redis->sUnionStore('output', 'key1', 'key2', 'key3');
$redis->sunionstore("uoutput","myset","myset1");
$data = $redis->smembers("uoutput");
echo "<pre>";
print_r($data);

//sort
// 排序,分页等
// 参数
// 'by' => 'some_pattern_*',
// 'limit' => array(0, 1),
// 'get' => 'some_other_pattern_*' or an array of patterns,
// 'sort' => 'asc' or 'desc',
// 'alpha' => TRUE,
// 'store' => 'external-key'

$data = $redis->sort("myset",array("sort"=>"desc"));
echo "<pre>";
print_r($data);

//ZSET 有序集合的相关操作
//zadd添加元素 zAdd(key, score, member):
for($i=0; $i < 10 ; $i++)
$redis->zadd("zset",$i+rand(10,99),$i+rand(100,999));

//zrange zRange(key, start, end,withscores) 返回指定范围的元素
//zRevRange(key, start, end,withscores):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素.withscores: 是否输出socre的值,默认false,不输出
//zRangeByScore, zRevRangeByScore
//$redis->zRangeByScore(key, star, end, array(withscores, limit ));
//返回名称为key的zset中score >= star且score <= end的所有元素
$data = $redis->zrange("zset",0,3,"withscores"); //end -1 返回所有元素 加withscores withscores做值 使用
echo "<pre>";
print_r($data);

//zDelete, zRem
//zRem(key, member) :删除名称为key的zset中的元素member
$redis->zrem("zset",456);

//zCount
//$redis->zCount(key, star, end);
//返回名称为key的zset中score >= star且score <= end的所有元素的个数
echo $redis->zcount("zset",10,50);

//zRemRangeByScore, zDeleteRangeByScore
$redis->zRemRangeByScore('key', star, end); //zremrangebyscore 删除 socre 大于star score 小于 end d的元素
//删除名称为key的zset中score >= star且score <= end的所有元素,返回删除个数

//zScore 返回名称为key的zset中元素val2的score
echo $redis->zScore("zset", 503);

//zRank, zRevRank zrank("set",value) 返回value 在集合中的位置 索引从0开始
echo $redis->zrank("zset",723);

//zIncrBy
//$redis->zIncrBy('key', increment, 'member');
//如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment
//zUnion/zInter 就集合的合集和交集

//HASH 哈希的相关操作
//hset 初始化数据
for( $i=0; $i < 10 ;$i++)
$redis->hset("myhash",$i,rand(10,99)+$i);

//hget("myhash","key1") 返回哈希 myhash 中键为key1的对应的数值
echo $redis->hget("myhash","0");
//hLen 返回名称为h的hash中元素个数
echo $redis->hlen('myhash');

//hDel 删除名称为h的hash中键为key1的域
echo $redis->hdel("myhash","0");
// hKeys 返回名称为key的hash中所有键
$data = $redis->hkeys('myhash');
//hVals 返回名称为h的hash中所有键对应的value
$data = $redis->hvals("myhash");
//hGetAll 返回名称为h的hash中所有的键(field)及其对应的value
$data = $redis->hgetall("myhash");
echo "<pre>";
print_r($data);
//hExists 判断某个hash的对应的键是否存在
echo $redis->hexists("myhash","0");
//hMset 向名称为key的hash中批量添加元素
$redis->hmset("user:1",array("name1"=>"name1","name2"=>"Joe2"));
//hMGet 返回名称为h的hash中field1,field2对应的value
$data = $redis->hmget('user:1', array('name', 'salary'));
echo "<pre>";
print_r($data);

//Redis 相关操作
//flushDB 清空当前数据库

//flushAll 清空所有数据库

//select 选择数据库
//$redis->select(0);
//move 把key1 移动到数据库2
$redis->move("key1",2);

//rename, renameKey 给key从新命名
//renameNx 与remane类似,但是,如果重新命名的名字已经存在,不会替换成功

//setTimeout, expire 设置key的生命时间
$redis->settimeout("user:1",10);

//expireat 指定一个key的生命时间为一个时间戳
//expireAt key存活到一个unix时间戳时间
$redis->expireat("myhash",time()+ 10);

//dbSize 查看现在数据库有多少key
$count = $redis->dbSize();

//auth 密码认证
$redis->auth('foobared');

//bgrewriteaof 使用aof来进行数据库持久化
$redis->bgrewriteaof();

//slaveof 通过执行 SLAVEOF host port 命令,可以将当前服务器转变为指定服务器的从属服务器(slave server)。
$redis->slaveof('10.0.1.7', 6379);

//save 将数据同步保存到磁盘
//bgsave 将数据异步保存到磁盘
//lastSave 返回上次成功将数据保存到磁盘的Unix时戳
//info 返回redis的版本信息等详情
echo "<pre>";
print_r($redis->info());

// type 返回key的类型值 1-5
//string: Redis::REDIS_STRING 1
//set: Redis::REDIS_SET 2
//list: Redis::REDIS_LIST 3
//zset: Redis::REDIS_ZSET 4
//hash: Redis::REDIS_HASH 5
//other: Redis::REDIS_NOT_FOUND 6
echo $redis->type("myset"); //2
参考技术A redis有单独的setTimeout方法吗?
是你使用的客户端设定的这个方法吧,对于redis中存储的key有过期超时时间设置,但是这个过期时间跟你的这个setTimeout明显不是一回事。
仔细看看你的客户端的这个方法操作的是啥

像 ehcache / redis 这样的外部缓存在哪里适合 w.r.t hibernate level 1 / level 2 缓存?

【中文标题】像 ehcache / redis 这样的外部缓存在哪里适合 w.r.t hibernate level 1 / level 2 缓存?【英文标题】:Where does external caches like ehcache / redis fit w.r.t hibernate level 1 / level 2 caches? 【发布时间】:2021-01-06 06:28:49 【问题描述】:

Hibernate(以及作为 hibernate 的包装器的 JPA)提供了两个级别的缓存机制。 a) 一级缓存,位于会话对象层/级别 b) 二级缓存,位于会话工厂层/级别

如果我使用的是 redis 或 ehcache 等外部缓存,那么这个缓存在上面的哪个位置。 或者我应该禁用 2 级缓存以启用 redis/ehcache。不确定外部缓存如何以及在何处适合 1 级和 2 级缓存。

或者 - 是否可以进行各种配置?

谁能解释一下。提前致谢。

【问题讨论】:

【参考方案1】:

一级缓存被认为是本地内存缓存,也可以是本地 Redis/Memcache 缓存。二级缓存就像一个代理服务器,缓存查询结果,任何服务器的所有后续查询都将提供缓存中的结果(如果可用)。

一级缓存结果仅对一台服务器可用,而二级缓存可以被视为对所有服务器都可用的分布式缓存。如果您的应用程序仅在一台服务器/实例上运行,那么使用 2 级缓存是没有意义的。

您也可以考虑为您的数据库使用代理服务器,例如,如果您使用的是 MySQL,那么您可以考虑使用 ProxySQL、mysql-proxy 等。

【讨论】:

感谢您的回复 - 如果您感兴趣,请提供类似的 Q。 What is the default cache strategy when using Redis with spring or spring boot? 如果您觉得这些答案有帮助,请接受。

以上是关于redis对象操作setTimeout(),在哪里可以查到用法?的主要内容,如果未能解决你的问题,请参考以下文章

setTimeout()和setInterval()的用法

js中setTimeout和setInterval的应用方法(转)

JS里设定延时:js中SetInterval与setTimeout用法

四个大点,搞懂 Redis 到底快在哪里?

学习js基础操作总结

在js对象的方法里有setTimeout函数,在setTimeout里怎么调用该对象方法,用this没有用