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

相关推荐
半个俗人2 小时前
06.Linux用户权限相关命令
linux·运维·服务器
GreatSQL2 小时前
一文搞懂 MySQL/GreateSQL 只读参数:read_only 参数核心区别
后端
Chris _data2 小时前
S7-1500 常用工业通信协议详解与对比
运维·服务器·网络
羊小猪~~2 小时前
【QT】-- 模型与视图简介
开发语言·数据库·c++·后端·qt·前端框架·个人开发
曲幽2 小时前
FastAPI里玩转Redis和数据库的正确姿势,别让异步任务把你坑哭了!
redis·python·mysql·fastapi·web·celery·sqlalchemy·task·backgroundtask
dashizhi20152 小时前
服务器共享文件禁止下载、禁止拖动共享文件到本地磁盘、禁止拷贝共享文件
运维·服务器·windows
古法安卓2 小时前
Android-NTP时间同步机制
后端
Memory_荒年3 小时前
Dubbo面试通关秘籍:从“小白”到“源码大神”的终极指南
java·后端·dubbo
PFinal社区_南丞3 小时前
Go 1.26 go fix 详解:18 个分析器一键现代化代码
后端