Redis学习笔记

本文详细介绍了Redis的学习笔记,涵盖了基础命令、客户端通信、单线程处理高并发、持久化策略(RDB与AOF)、事务与Lua脚本、发布订阅机制,以及复制原理。重点讨论了Pipeline优化RTT、Lua在Redis中的应用和复制过程中的部分同步。通过实例解析了Redis的高效使用和常见问题。
摘要由CSDN通过智能技术生成

第3章 小功能大用处
3.3 Pipeline
1.Redis客户端执行命令过程
1) 发送命令 2) 命令排队 3) 命令执行 4) 返回结果
1)+4)称为Round Trip Time(RTT,往返时间)
Redis提供了批量操作命令(例如mget、mset等),有效地节约RTT。要执行n次hgetall,并没有mhgetall命令存在,需要消耗n次RTT。
Pipeline(流水线)机制将一组命令组装,一次传输给Redis,节约RTT(Pipeline结果是一次还是n次返回,我猜是一次->看源码 TODO)
Redis命令真正执行的时间通常在微秒级别,因此Redis性能瓶颈是网络

 echo -en '*3\r\n$3\r\nSET\r\n$5\r\nhello\r\n$5\r\nworld\r\n*2\r\n$4\r\nincr\r\
   n$7\r\ncounter\r\n' | redis-cli --pipe
  1. 原生批量命令与Pipeline对比
    (1)原生批量命令是原子的,Pipeline是非原子的
    (2)原生批量命令是一个命令对应多个key,Pipeline支持多个命令
    (3)原生批量命令是Redis服务端支持实现的,Pipeline需要服务端和客户端的共同实现

3.4 事务与Lua
保证多条命令组合的原子性,事务+Lua脚本实现
3.4.1 事务
事务表示一组动作,要么全部执行,要么全部不执行

    # 命令放到multi、exec两个命令之间,就能使用事务
    127.0.0.1:6379> multi
    OK
    127.0.0.1:6379> sadd user:a:follow user:b
    QUEUED
    127.0.0.1:6379> sadd user:b:fans user:a
    QUEUED
    # 另一个客户端访问
    127.0.0.1:6379> sismember user:a:follow user:b
    (integer) 0
    
    127.0.0.1:6379> exec
    1) (integer) 1
    2) (integer) 1
    127.0.0.1:6379> sismember user:a:follow user:b
    (integer) 1

    # discard命令,停止事务的执行
    127.0.0.1:6379> discard
    OK
    127.0.0.1:6379> sismember user:a:follow user:b
    (integer) 0

1.命令错误

# 将set写成了sett,属于语法错误
127.0.0.1:6388> mget key counter
1) "hello"
2) "100"
127.0.0.1:6388> multi
OK
127.0.0.1:6388> sett key world
(error) ERR unknown command 'sett'
127.0.0.1:6388> incr counter
QUEUED
127.0.0.1:6388> exec
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6388> mget key counter
1) "hello"
2) "100"

2.运行时错误

# 用户B在添加粉丝列表时,误把sadd命令写成了zadd命令
127.0.0.1:6379> multi
OK
127.0.0.1:6379> sadd user:a:follow user:b
QUEUED
127.0.0.1:6379> zadd user:b:fans 1 user:a
QUEUED
127.0.0.1:6379> exec
1) (integer) 1
2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
127.0.0.1:6379> sismember user:a:follow user:b
(integer) 1

上述sadd user🅰️follow user:b执行成功,Redis并不支持回滚功能

有些场景在事务之前,确保事务中的key没有被其他客户端修改过,才能执行事务,否则不执行(类似乐观锁)

# T1:客户端1
127.0.0.1:6379> set key "java"
OK
# T2:客户端1
127.0.0.1:6379> watch key
OK
# T3:客户端1
127.0.0.1:6379> multi
OK
# T4:客户端2
127.0.0.1:6379> append key python
(integer) 11
# T5:客户端1
127.0.0.1:6379> append key jedis
QUEUED
# T6:客户端1
127.0.0.1:6379> exec
(nil)
# T7:客户端1
127.0.0.1:6379> get key
"javapython"

提供简单事务功能,体现Redis的“keep it simple”的特性

3.4.2 Lua用法简述
Web服务器Nginx将Lua语言作为扩展,增强自身功能
1.Lua数据类型及其逻辑处理
booleans(布尔)、numbers(数值)、strings(字符串)、tables(表格)
Lua的数组下标从1开始计算(mysql str下标也是从1开始 TODO)

3.4.3 Redis与Lua
1.在Redis中使用Lua
Redis执行Lua脚本有两种方法:eval、evalsha

# eval 脚本内容 key个数 key列表 参数列表
127.0.0.1:6379> eval 'return "hello " .. KEYS[1] .. ARGV[1]' 1 redis world
"hello redisworld"
# 执行脚本文件
redis-cli--eval ./hahaha.lua

# 将Lua脚本加载到Redis服务端,得到该脚本的SHA1, evalsha命令使用SHA1作为参数执行对应Lua脚本,避免每次发送Lua脚本的开销   
redis-cli script load "$(cat lua_get.lua)"
"7413dc2440db1fea7c0a0bde841fa68eefaf149c"
# evalsha 脚本SHA1值 key个数 key列表 参数列表
127.0.0.1:6379> evalsha 7413dc2440db1fea7c0a0bde841fa68eefaf149c 1 redis world
"hello redisworld"

2.Lua的Redis API

# lua代码调用Redis
redis.call("set", "hello", "world")
redis.call("get", "hello")
# 放在Redis执行
127.0.0.1:6379> eval 'return redis.call("get", KEYS[1])' 1 hello
 "world"

redis.call执行失败,脚本执行结束返回错误;redis.pcall会忽略错误继续执行脚本
Redis3.2提供了Lua Script Debugger功能用来调试复杂的Lua脚本,具体可以参考:ht

尚硅谷是一个教育机构,他们提供了一份关于Redis学习笔记。根据提供的引用内容,我们可以了解到他们提到了一些关于Redis配置和使用的内容。 首先,在引用中提到了通过执行命令"vi /redis-6.2.6/redis.conf"来编辑Redis配置文件。这个命令可以让你进入只读模式来查询"daemonize"配置项的位置。 在引用中提到了Redis会根据键值计算出应该送往的插槽,并且如果不是该客户端对应服务器的插槽,Redis会报错并告知应该前往的Redis实例的地址和端口。 在引用中提到了通过修改Redis的配置文件来指定Redis的日志文件位置。可以使用命令"sudo vim /etc/redis.conf"来编辑Redis的配置文件,并且在文件中指定日志文件的位置。 通过这些引用内容,我们可以得出结论,尚硅谷的Redis学习笔记涵盖了关于Redis的配置和使用的内容,并提供了一些相关的命令和操作示例。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Redis学习笔记--尚硅谷](https://blog.csdn.net/HHCS231/article/details/123637379)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Redis学习笔记——尚硅谷](https://blog.csdn.net/qq_48092631/article/details/129662119)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值