redis 介绍和常用命令
- 作者: 五速梦信息网
- 时间: 2026年04月04日 13:29
redis 介绍和常用命令
redis简介
Redis 是一款开源的,基于 BSD 许可的,高级键值 (key-value) 缓存 (cache) 和存储 (store) 系统。由于 Redis 的键包括 string,hash,list,set,sorted set,bitmap 和 hyperloglog,所以常常被称为数据结构服务器。你可以在这些类型上面运行原子操作,例如,追加字符串,增加哈希中的值,加入一个元素到列表,计算集合的交集、并集和差集,或者是从有序集合中获取最高排名的元素。
为了满足高性能,Redis 采用内存 (in-memory) 数据集 (dataset)。根据你的使用场景,你可以通过每隔一段时间转储数据集到磁盘,或者追加每条命令到日志来持久化。持久化也可以被禁用,如果你只是需要一个功能丰富,网络化的内存缓存。
Redis 还支持主从异步复制,非常快的非阻塞初次同步、网络断开时自动重连局部重同步。 其他特性包括:
- 事务
- 订阅/发布
- Lua 脚本
- 带 TTL 的键
- LRU 回收健
- 自动故障转移 (failover)
你可以通过多种语言来使用 Redis。
Redis 是由 ANSI C 语言编写的,在无需额外依赖下,运行于大多数 POSIX 系统,如 Linux、*BSD、OS X。Redis 是在 Linux 和 OS X 两款操作系统下开发和充分测试的,我们推荐 Linux 为部署环境。Redis 也可以运行在 Solaris 派生系统上,如 SmartOS,但是支持有待加强。没有官方支持的 Windows 构建版本,但是微软开发和维护了一个 64 位 Windows 的版本。
更多介绍:
wikipedia:
Redis is an in-memory database open-source software project sponsored by Redis Labs. It is networked, in-memory, and stores keys with optional durability.
redis.io
Redis is an open source (BSD licensed), in-memory data structure store, used as a database, cache and message broker. It supports data structures such as strings, hashes, lists, sets, sorted sets with range queries, bitmaps, hyperloglogs and geospatial indexes with radius queries. Redis has built-in replication, Lua scripting, LRU eviction, transactions and different levels of on-disk persistence, and provides high availability via Redis Sentinel and automatic partitioning with Redis Cluster.
redis 配置
linux 配置
linux 下载安装参考官网 https://redis.io/download
windows 配置
redis 官网没有提供Windows的支持,不过微软的开源团队做了一个Windows版本的,项目地址:https://github.com/MSOpenTech/redis,顿时想感慨一番,微软大法好!!!
从这里 https://github.com/MSOpenTech/redis/releases 下载 redis Windows版本,这里想再感慨一下,我上次配置的时候是用的 2.4.5 版本,那个版本的配置还需要自己手动执行命令安装服务,手动配置环境变量,现在一切都自动化了,安装好之后服务自动安装并且安装的时候,可以选择将安装目录添加到环境变量,真的是方便了好多。
下载最新的 release 版安装包之后,解压安装即可,建议添加到环境变量。
redis 常用命令
连接远程 redis 服务器
redis-cli -h hostname/ip [-p port] [-a password] redis-cli - 172.16.20.233 -p 6379
参数说明
requirepass
基本操作
注:命令名不区分大小写,key 和 value 是区分大小写的
# 选择数据库,默认使用index为0的数据库
SELECT index获取缓存中的 key
# 查看缓存中所有 key
KEYS *模糊匹配查询缓存中的 key
KEYS aa*
KEYS *aaa
KEYS aa*bb判断key是不是存在
EXISTS key [key…]
返回值说明
# - 1:存在
# - 0:不存在根据key获取value
GET key
返回值说明
# - (nil):key不存在
根据key获取value的substring
GETRANGE key start end
更新key的value返回旧的value
GETSET key value
同时获取多个key的值
MGET key [key …]
设置/更新缓存的值
SET key value [EX seconds] [PX milliseconds] [NX|XX]
参数说明
# - EX :设置过期时间,单位是秒
# - PX :设置过期时间,单位毫秒
# - NX : 只有key不存在时才设置key的value
# - XX :只有key存在时才设置key的value SET key value PX milliseconds
SET key value EX seconds NX
SET key value XX只有key不存在时才设置,和
SET key value NX效果一样SETNX key value
重写key对应value的一部分
SETRANGE key offset value
获取key对应value的长度
STRLEN key
根据key删除缓存中的值
DEL key [key…]
integer 类型的值减一
DECR key
integer 类型的值减小 decrement
DECRBY key decrement
integer类型的值加一
INCR key
integer 类型的值减小 increment
INCRBY key increment
更多 key 操作
# 以秒为单位设置key过期时间
EXPIRE key seconds以秒为单位设置key过期时间的UNIX时间戳
EXPIREAT key timestamp
以毫秒为单位设置key过期时间
PEXPIRE key milliseconds
以毫秒为单位设置key过期时间的UNIX时间戳
PEXPIREAT key milliseconds-timestamp
移动key到另外一个database
MOVE key db
移除key的过期时间,设置为不过期
PERSIST key
获取key的剩余生存时间单位为秒,还有多长时间过期单位为秒
TTL key #返回值说明
# -2:key不存在
# -1:key存在但是没有设置过期时间获取key的剩余生存时间单位为毫秒,还有多长时间过期单位为毫秒
PTTL key
获取一个随机生成的 key
RANDOMKEY
重命名一个 key
RENAME key newkey
获取key存储的value的数据类型
TYPE key
list 或 set 排序
SORT key
更多命令
远程 Redis 调试
- 连接远程 redis 服务器
# 匿名访问
redis-cli -h 172.16.20.233 -p 6479
密码访问
redis-cli -h 172.16.20.233 -p 6479 -a p@ssword
- 利用keys模糊查询,查询 key 的完整名称
# 以 aaa 结尾的 key
keys *aaa
以 aaa 开头的 key
keys aaa*
完全模糊匹配包含 aaa 的key
keys aaa
(empty list or set)
get key
- 手动更新key的value
set key value [EX seconds]
- 删除key
del key
More
redis客户端
redis有丰富的客户端支持,如果想要获取一个完整的列表,可以访问这里 https://redis.io/clients
redis 命令
reids 文档
redis 下载
redis 下载
End
想不起来写点什么好了,想起来再写吧,有什么问题或疑问欢迎可以随时和我联系 weihanli@outlook.com
- 上一篇: Redis 哨兵模式高可用
- 下一篇: redis 根据key 导出






