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 数据结构是什么?

相关推荐
葫芦和十三5 小时前
图解 MongoDB 07|索引类型:七种索引,七种访问形状
后端·mongodb·agent
朦胧之7 小时前
AI 编程-老项目改造篇
java·前端·后端
swipe10 小时前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
爱勇宝10 小时前
我做了一个只用来搜歌词的小 App
android·前端·后端
IT_陈寒11 小时前
SpringBoot自动配置坑了我一晚上,原来问题出在这
前端·人工智能·后端
SelectDB11 小时前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
SelectDB11 小时前
秒级弹性、最高降本 70%:SelectDB Serverless 如何重塑云数仓资源效率
大数据·后端·云原生
PinkSun11 小时前
Spring AI ChatMemory踩坑实录:重启丢数据、Agent丢记忆、对话溢出
后端·ai编程
壹方秘境12 小时前
我用Go语言开发了一个跨平台的HTTPS抓包和调试工具
前端·后端·ios
神秘面具男12 小时前
HarmonyOS 6.0跨端远程控制
前端·后端