在测试环境中,可以使用 keys 命令,模糊查询到需要的 key,但这个操作只适合在测试环境中使用,不适合在生产环境中使用,原因是 Redis 是单线程运行的,当 Redis 中的数据量很大时,由于此操作会遍历所有数据,并将结果一次性全部返回,执行时间会比较长,从而导致后续操作等待,直接影响系统的正常运行。集群环境下使用 jedis 的代码实现。
一、keys命令用法keys命令用于返回指定的正则表达式所匹配的所有key的列表,其所检索的是Redis当前所使用的数据库(默认为0号数据库)的所有key,用法如下:1. *匹配数据库中所有key KEYS *2. ?匹配某个字符KEYS t?st3.
Redis支持的各种数据类型包括string,list ,set ,sorted set 和hash .Redis本质上一个key-value db,所以我们首先来看看他的key。首先key也是字符串类型,但是key中不能包括边界字符。
一个请求进来后,先去redis进行查找,redis存在,则返回,不存在则查询数据数据库,数据存在则放到redis中,但是key对应的数据有可能在数据库中也不存在,每次从缓存中获取不到数据,请求就会压到数据库,可能导致压垮数据库。
特点:使用阻塞的 I/O,方法调用同步,程序流需要等到 socket 处理完 I/O 才能执行,不支持异步操作。Lettuce 的 API 是线程安全的,所以可以操作单个 Lettuce 连接来完成各种操作。