灵魂之旅:Redis笔记
Redis是一个get="_blank">高性能的键值对存储系统,它支持多种数据结构,包括String,Hash,List,Set和Sorted Set,另外还提供了发布/订阅机制和Lua脚本扩展等功能。Redis的性能极佳,除了在速度上要比传统关系数据库快得多之外,还具有强大的缓存能力,因此广泛应用于缓存、消息队列、排行榜等领域。
一、Redis基本语法
1. 连接Redis
连接Redis只需要执行以下命令即可:
2. 设置/获取值
设置值:
set key value
获取值:
3. 删除值
删除值:
二、Redis的数据结构

String是Redis最基本的数据结构,它可以存储任何的字符串,包括二进制数据。
设置String值:
set key value
获取String值:
Hash是存储键值对的数据结构,其中每个键都对应一个值,同一个Hash中不同的键可以对应不同的值。
设置Hash值:
hset key field value
获取Hash值:
hget key field
获取Hash中的所有键值对:
hgetall key
List是有序的字符串列表,它可以存储重复的元素,而且支持在列表的两端进行添加、删除操作。
将元素添加到List中:
lpush key value1 value2
将元素从List中删除:
获取List中的元素:
lrange key start end
Set是无序的字符串集合,它可以存储不重复的元素。
将元素添加到Set中:
sadd key member1 member2
从Set中删除元素:
srem key member
获取Set中的所有元素:
smembers key
5. Sorted Set
Sorted Set是有序的字符串集合,它与普通的Set类似,可以存储不重复的元素,但Sorted Set可以对每个元素进行排序。
将元素添加到Sorted Set中:
zadd key score1 member1 score2 member2
从Sorted Set中删除元素:
zrem key member
获取Sorted Set中的所有元素:
zrange key start end
三、Redis的高级功能
1. 发布/订阅机制
Redis支持发布/订阅机制,可以通过场景模拟模拟一个发布/订阅系统,代码实现如下:
# 发布
publish channel message
# 订阅
subscribe channel
2. Lua脚本扩展
Lua脚本扩展可以在Redis中执行Lua脚本,从而进行复杂的操作,代码实现如下:
# 执行Lua脚本
eval script key1 key2 …
3. 缓存
Redis具有强大的缓存能力,在实际项目中可以使用Redis作为缓存,从而提高应用程序的响应速度。下面是Redis缓存的实现代码:
import redis
r = redis.Redis(host=’localhost’, port=6379, db=0)
def get_cache(key):
value = r.get(key)
return value
# 从数据库中获取数据
value = get_data_from_database(key)
# 将数据存入Redis中
r.set(key, value)
return value
4. 事务和原子性
Redis提供了事务和原子性的支持,可以保证一组操作要么全部执行成功,要么全部执行失败。代码实现如下:
# 开启事务
# 执行操作
set key1 value1
set key2 value2
# 提交事务
Redis是一个强大、高性能、灵活的存储系统,通过熟悉Redis的基本语法和高级功能,我们可以更好地应用Redis来提高应用程序的性能和响应速度。
香港服务器首选树叶云,2H2G首月10元开通。树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云 服务器 和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
redis集合和有序集合的区别
如果是使用的del命令.是会释放内存的.c//....187 void delCommand(redisClient *c)//....191 if (dbDelete(c- > db,c- > argv[j])) {//....131 int dbDelete(redisDb *db, robj *key) {//...140 return dictDelete(db- > dict,key- > ptr) == DICT_OK;
redis怎么在windows上安装
在linux环境下Redis可以直接通过源码编译安装。 Windows下编译一般不那么方便,我们使用已经编译好的安装包来安装。 首先找到Windows下的Redis安装包打开官网下载页面找到Windows项然后点击“Learn more”,打开github项目找到Redis安装包并下载在上一步打开github页面中下拉找到里面的Redis on Windows项,这里有一句”You can download the latest unsigned binaries and the unsigned MSI installer from the release page.“.点击”release page“打开下载页面,这里可以选择对应的版本下载。 这里我选择版本3.0.501然后在页面下点击“下载安装包3安装Redis下载之后双击打开安装配置页面,一般来说默认即可,但是你要知道配置项的意思,根据具体情况配置。 最后点击install即可安装。 启动Redis安装之后发现安装目录F:\ProgramFiles\Redis有很多文件。 这里就和linux下一样了。 进入redis安装目录后 开启服务 执行下面的命令:$ ./ [] 22 Mar 02:39:36.897 # Creating server TCP listening socket *:6379: bind:Unknown error如果出现上面的错误查看端口是否被占用,我的是右击有服务开启了,关掉重新执行命令即可;网上看到有人说开启一个命令行窗口 进入redis目录下,执行 -h 127.0.0.1 -p 6379 这样连接服务,不过我这里没执行成功。 我直接双击 即可打开终端,试了下ok。 这里顺利在Windows上面安装Redis,当然还有很多更深的东西在,这里就不多说了,有兴趣的同学可以从运维的角度和开发的角度分别进一步学习Redis
redis db 和key的区别
Redis中的DB是相互独立存在的,所以可以出现重复的key。 好处一直是,对小型项目可以做如下设置: 1号DB做开发,2号DB做测试等等。 。 0 volatile: 目前0号DB中没有volatile key,volatile key的意思是 过特定的时间就被REDIS自动删除
发表评论