我们一起了解Redis的爱恨情仇

Redis是一个key-value 存储系统,是跨平台的非关系型数据库。

Redis 是一个开源的使用 ANSI C 语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式、可选持久性的键值对(Key-Value)存储数据库,并提供多种语言的 API。

Redis 通常被称为数据结构服务器,因为值(value)可以是字符串(String)、哈希(Hash)、列表(list)、集合(sets)和有序集合(sorted sets)等类型。

redis的安装介质在:https://github.com/tporadowski/redis/releases

下载后运行得到一个运行路径。

修改redis.windows-service.conf文件,一个是端口,一个是密码认证

#bind 127.0.0.1             #注释掉这一句,使redis可以外部访问
port 6379 #默认端口,可以改成别的端口
protected-mode yes #修改为yes,开启保护模式,默认是yes
#daemonize no #这一句是注释的,windows版本不支持,默认是no
requirepass 123456 #密码
appendonly yes

进行指定目录下,运行redis

# 启动redis失败 Could not create server TCP listening socket 127.0.0.1:6379: bind: 操作成功

操作办法:

redis命令,设置key,value值

上面提到的字符串(String)、哈希(Hash)、列表(list)、集合(sets)和有序集合(sorted sets)等类型,具体操作也不复杂

C:\Program Files\Redis>redis-cli.exe-h 127.0.0.1-p 6379
127.0.0.1:6379> ping
PONG
127.0.0.1:6379>set key1 v1
OK
127.0.0.1:6379> get key1
"v1"
127.0.0.1:6379> get key
(nil)
127.0.0.1:6379>set name "wbq"
OK
127.0.0.1:6379> get name
"wbq"
127.0.0.1:6379>set name "whp"
OK
127.0.0.1:6379> get name
"whp"
127.0.0.1:6379> del name
(integer)1
127.0.0.1:6379> hmset name field1 "wbq" field2 "whp"
OK
127.0.0.1:6379> hget name field1
"wbq"
127.0.0.1:6379> hget name field2
"whp"
127.0.0.1:6379> lpush alist redis
(integer)1
127.0.0.1:6379> lpush alist db2
(integer)2
127.0.0.1:6379> lpush alist mysql
(integer)3
127.0.0.1:6379> lrange alist 02
1)"mysql"
2)"db2"
3)"redis"
127.0.0.1:6379> lrange alist 01
1)"mysql"
2)"db2"
127.0.0.1:6379> sadd aset set1
(integer)1
127.0.0.1:6379> sadd aset set2
(error) MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk. Commands that may modify the data set are disabled, because this instance is configured to report errors during writes if RDB snapshotting fails (stop-writes-on-bgsave-error option). Please check the Redis logs for details about the RDB error.
127.0.0.1:6379> sadd aset set3
(error) MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk. Commands that may modify the data set are disabled, because this instance is configured to report errors during writes if RDB snapshotting fails (stop-writes-on-bgsave-error option). Please check the Redis logs for details about the RDB error.
127.0.0.1:6379> sadd aset set3 [member ...]

又报错了,(error) MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk. Commands that may modify the data set are disabled, because this instance is configured to report errors during writes if RDB snapshotting fails (stop-writes-on-bgsave-error option). Please check the Redis logs for details about the RDB error.

大意就是说无法持久化写入磁盘,进行配置

127.0.0.1:6379> config set stop-writes-on-bgsave-error no
OK
127.0.0.1:6379> sadd aset set2
(integer)1
127.0.0.1:6379> sadd aset set3
(integer)1
127.0.0.1:6379> sadd aset set4
(integer)1
127.0.0.1:6379> sadd aset set2
(integer)0
127.0.0.1:6379> smembers aset
1)"set4"
2)"set3"
3)"set1"
4)"set2"
127.0.0.1:6379>

查看服务端错误日志,大意是说没有写入权限

[34752]27 Apr 11:50:16.328 # fork operation complete
[34752]27 Apr 11:50:16.340 # Background saving error
[34752]27 Apr 11:50:22.046*1 changes in900 seconds. Saving...
[34752]27 Apr 11:50:22.115* Background saving started by pid 7944
[7944]27 Apr 11:50:22.251 # Failed opening the RDB file dump.rdb(in server root dir C:\Program Files\Redis) for saving: 数据无效。
[7944]27 Apr 11:50:22.253 # rdbSave failed in qfork: Permission denied
[34752]27 Apr 11:50:22.325 # fork operation complete
[34752]27 Apr 11:50:22.338 # Background saving error
[34752]27 Apr 11:50:28.046*1 changes in900 seconds. Saving...
[34752]27 Apr 11:50:28.112* Background saving started by pid 20004
[20004]27 Apr 11:50:28.229 # Failed opening the RDB file dump.rdb(in server root dir C:\Program Files\Redis) for saving: 数据无效。
[20004]27 Apr 11:50:28.231 # rdbSave failed in qfork: Permission denied

对文件夹的读写权限进行变更后,一切正常

[34752]27 Apr 11:50:28.326 # fork operation complete
[34752]27 Apr 11:50:28.343 # Background saving error
[34752]27 Apr 11:50:34.060*1 changes in900 seconds. Saving...
[34752]27 Apr 11:50:34.126* Background saving started by pid 32840
[34752]27 Apr 11:50:34.339 # fork operation complete
[34752]27 Apr 11:50:34.383* Background saving terminated with success

继续进行各类型键值操作。

127.0.0.1:6379> zadd asortedset 0 redis
(integer)1
127.0.0.1:6379> zadd asortedset 1 db2
(integer)1
127.0.0.1:6379> zadd asortedset 0 sqlserver
(integer)1
127.0.0.1:6379> zrangebyscore asortedset 05
1)"redis"
2)"sqlserver"
3)"db2"
127.0.0.1:6379>

Redis支持多个数据库,并且每个数据库的数据是隔离的不能共享,并且基于单机才有,如果是集群就没有数据库的概念。

Redis是一个字典结构的存储服务器,而实际上一个Redis实例提供了多个用来存储数据的字典,客户端可以指定将数据存储在哪个字典中。这与我们熟知的在一个关系数据库实例中可以创建多个数据库类似,所以可以将其中的每个字典都理解成一个独立的数据库。

每个数据库对外都是一个从0开始的递增数字命名,Redis默认支持16个数据库(可以通过配置文件支持更多,无上限),可以通过配置databases来修改这一数字。客户端与Redis建立连接后会自动选择0号数据库,不过可以随时使用SELECT命令更换数据库,如要选择1号数据库:

127.0.0.1:6379>select1
OK
127.0.0.1:6379[1]> get key1
(nil)
127.0.0.1:6379[1]> zrangebyscore asortedset 05
(empty list orset)
127.0.0.1:6379[1]>select0
OK
127.0.0.1:6379> zrangebyscore asortedset 05
1)"redis"
2)"sqlserver"
3)"db2"
127.0.0.1:6379>select2
OK
127.0.0.1:6379[2]> zrangebyscore asortedset 05
(empty list orset)
127.0.0.1:6379[2]>

其实我真正的目的是为了实现一个最近24小时数据的队列,确保数据是持续滚动的

构建一个list列表键值,通过rpush实现24条记录写入,查看数据,持续lpop和rpush可实现一个队列,现在欠缺的是一个元数据了。

127.0.0.1:6379> del  userdaydata:username:user1:data
(integer)1
127.0.0.1:6379> rpush userdaydata:username:user1:data 01234567891011121314151617181920212223
(integer)24
127.0.0.1:6379> lrange userdaydata:username:user1:data 023
1)"0"
2)"1"
3)"2"
4)"3"
5)"4"
6)"5"
7)"6"
8)"7"
9)"8"
10)"9"
11)"10"
12)"11"
13)"12"
14)"13"
15)"14"
16)"15"
17)"16"
18)"17"
19)"18"
20)"19"
21)"20"
22)"21"
23)"22"
24)"23"
127.0.0.1:6379> lpop userdaydata:username:user1:data
"0"
127.0.0.1:6379> lrange userdaydata:username:user1:data 023
1)"1"
2)"2"
3)"3"
4)"4"
5)"5"
6)"6"
7)"7"
8)"8"
9)"9"
10)"10"
11)"11"
12)"12"
13)"13"
14)"14"
15)"15"
16)"16"
17)"17"
18)"18"
19)"19"
20)"20"
21)"21"
22)"22"
23)"23"
127.0.0.1:6379> rpush userdaydata:username:user1:data 0
(integer)24
127.0.0.1:6379> lrange userdaydata:username:user1:data 023
1)"1"
2)"2"
3)"3"
4)"4"
5)"5"
6)"6"
7)"7"
8)"8"
9)"9"
10)"10"
11)"11"
12)"12"
13)"13"
14)"14"
15)"15"
16)"16"
17)"17"
18)"18"
19)"19"
20)"20"
21)"21"
22)"22"
23)"23"
24)"0"
127.0.0.1:6379> lpop userdaydata:username:user1:data
"1"
127.0.0.1:6379> lrange userdaydata:username:user1:data 023
1)"2"
2)"3"
3)"4"
4)"5"
5)"6"
6)"7"
7)"8"
8)"9"
9)"10"
10)"11"
11)"12"
12)"13"
13)"14"
14)"15"
15)"16"
16)"17"
17)"18"
18)"19"
19)"20"
20)"21"
21)"22"
22)"23"
23)"0"
127.0.0.1:6379> rpush userdaydata:username:user1:data 1
(integer)24
127.0.0.1:6379> lrange userdaydata:username:user1:data 023
1)"2"
2)"3"
3)"4"
4)"5"
5)"6"
6)"7"
7)"8"
8)"9"
9)"10"
10)"11"
11)"12"
12)"13"
13)"14"
14)"15"
15)"16"
16)"17"
17)"18"
18)"19"
19)"20"
20)"21"
21)"22"
22)"23"
23)"0"
24)"1"
127.0.0.1:6379>

后文会将如何通过python进行redis操作。

参考1:https://blog.csdn.net/qq_45047809/article/details/112529734

参考2:https://www.runoob.com/redis/redis-tutorial.html

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/260734.html<

(0)
运维的头像运维
上一篇2025-05-03 07:26
下一篇 2025-05-03 07:27

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注