Redis复习记录Day03

Redis 字符串类型的最大值大小是多少?

java 复制代码
public void setBigString(String key, String value, int chunkSize) {
    int chunks = (value.length() + chunkSize - 1) / chunkSize;
    Pipeline pipeline = jedis.pipelined();
    for (int i = 0; i < chunks; i++) {
        int start = i * chunkSize;
        int end = Math.min(start + chunkSize, value.length());
        pipeline.set(key + ":" + i, value.substring(start, end));
    }
    pipeline.set(key + ":chunks", String.valueOf(chunks));
    pipeline.sync();
}

public String getBigString(String key) {
    int chunks = Integer.parseInt(jedis.get(key + ":chunks"));
    List<String> keys = new ArrayList<>();
    for (int i = 0; i < chunks; i++) {
        keys.add(key + ":" + i);
    }
    List<String> values = jedis.mget(keys.toArray(new String[0]));
    return String.join("", values);
}
java 复制代码
public void setCompressed(String key, String value) {
    byte[] compressed = Snappy.compress(value.getBytes(StandardCharsets.UTF_8));
    jedis.set(key.getBytes(), compressed);
}

public String getCompressed(String key) {
    byte[] compressed = jedis.get(key.getBytes());
    return new String(Snappy.uncompress(compressed), StandardCharsets.UTF_8);
}

Redis 性能瓶颈时如何处理?

java 复制代码
# 查看实时性能指标
redis-cli info stats

# 慢查询日志,超过 10ms 的命令都记下来
config set slowlog-log-slower-than 10000
slowlog get 10

# 内存分析
memory doctor
memory stats

Redis 集群的实现原理是什么?

Redis 中 EMBSTR 对象的阈值设置为何为 44?其调整历史是什么?

Redis List 类型的常见操作命令有哪些?

java 复制代码
# 写入操作
LPUSH mylist a b c     # list 变成 [c, b, a]
RPUSH mylist d e       # list 变成 [c, b, a, d, e]

# 弹出操作
LPOP mylist            # 返回 c,list 变成 [b, a, d, e]
RPOP mylist            # 返回 e,list 变成 [b, a, d]

# 读取操作
LRANGE mylist 0 -1     # 返回 [b, a, d]
LINDEX mylist 1        # 返回 a
LLEN mylist            # 返回 3

# 修改操作
LSET mylist 0 x        # list 变成 [x, a, d]
LREM mylist 1 a        # 删掉第一个 a,list 变成 [x, d]
LTRIM mylist 0 0       # 只保留第一个元素,list 变成 [x]

如何在 Redis 中实现队列和栈数据结构?

java 复制代码
# 队列:先进先出
LPUSH myqueue "task1"
LPUSH myqueue "task2"
RPOP myqueue   # 弹出 "task1"

# 栈:后进先出
LPUSH mystack "item1"
LPUSH mystack "item2"
LPOP mystack   # 弹出 "item2"
java 复制代码
while(true) {
    // 最多等 5 秒,超时返回 null
    msg = redis.brpop("queue", 5);
    if (msg == null) {
        // 超时了,可以干点别的
        continue;
    }
    process(msg);
}
java 复制代码
ZADD priority_queue 1 "low_priority_task"
ZADD priority_queue 0 "high_priority_task"
ZPOPMIN priority_queue  # 弹出 "high_priority_task"

Redis 中的 Ziplist 和 Quicklist 数据结构的特点是什么?

Redis 复制延迟的常见原因有哪些?

Redis 事务与关系型数据库事务的主要区别是什么?

java 复制代码
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET user:1:name "zhangsan"
QUEUED
127.0.0.1:6379> SET user:1:age 25
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) OK
java 复制代码
127.0.0.1:6379> WATCH balance
OK
127.0.0.1:6379> GET balance
"100"
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> DECRBY balance 50
QUEUED
127.0.0.1:6379> EXEC
# 如果 balance 在 WATCH 后被其他客户端修改了,这里返回 nil

Redis 的 ListPack 数据结构是什么?

相关推荐
GetcharZp18 小时前
告别 jq 噩梦!这款 JSON 神器 fx 让你在终端体验“丝滑”的数据操作
后端
桌面运维家19 小时前
IDV云桌面vDisk机房网络管控访问限制部署方案
运维·服务器·网络
ShineWinsu19 小时前
对于Linux:动静态库的制作与原理的解析—下
linux·运维·服务器·进程·链接·虚拟地址空间·
小码哥_常20 小时前
告别臃肿!Elasticsearch平替Manticore登场
后端
RH23121120 小时前
2026.4.16Linux 管道
java·linux·服务器
测试199820 小时前
2026最新软件测试面试八股文【附文档】
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
zmsofts20 小时前
java面试必问13:MyBatis 一级缓存、二级缓存:从原理到脏数据,一篇讲透
java·面试·mybatis
handler0121 小时前
Linux: 基本指令知识点(2)
linux·服务器·c语言·c++·笔记·学习
苍何21 小时前
万字保姆级教程:Hermes+Kimi K2.6 打造7x24h Agent军团
后端
我叫黑大帅21 小时前
为什么map查找时间复杂度是O(1)?
后端·算法·面试