y23335793 发表于 2017-12-21 14:14:09

redis 介绍和常用命令

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 版本,那个版本的配置还需要自己手动执行命令安装服务,手动配置环境变量,现在一切都自动化了,安装好之后服务自动安装并且安装的时候,可以选择将安装目录添加到环境变量,真的是方便了好多。

  下载最新的>
redis 常用命令

连接远程 redis 服务器
  

1 redis-cli -h hostname/ip [-p port] [-a password]  

2  
3 redis-cli - 172.16.20.233 -p 6379
  

  参数说明


[*]-h 域名或IP
[*]-p 端口号(默认端口号是6379)
[*]-a 访问密码(默认是不需要密码访问的,如果要设置密码可以修改 redis.conf 的requirepass节点)
基本操作
  注:命令名不区分大小写,key 和 value 是区分大小写的
  

1 # 选择数据库,默认使用index为0的数据库  
2 SELECT index
  
3
  
4 # 获取缓存中的 key
  
5 # 查看缓存中所有 key
  
6 KEYS *
  
7
  
8 # 模糊匹配查询缓存中的 key
  
9 KEYS aa*
  
10 KEYS *aaa
  
11 KEYS aa*bb
  
12
  
13 # 判断key是不是存在
  
14 EXISTS key
  
15
  
16 # 返回值说明
  
17 # - 1:存在
  
18 # - 0:不存在
  
19
  
20 # 根据key获取value
  
21 GET key
  
22
  
23 # 返回值说明
  
24 # - (nil):key不存在
  
25
  
26 # 根据key获取value的substring
  
27 GETRANGE key start end
  
28
  
29 # 更新key的value返回旧的value
  
30 GETSET key value
  
31
  
32 # 同时获取多个key的值
  
33 MGET key
  
34
  
35 # 设置/更新缓存的值
  
36 SET key value
  
37
  
38 # 参数说明
  
39 # - EX :设置过期时间,单位是秒
  
40 # - PX :设置过期时间,单位毫秒
  
41 # - NX : 只有key不存在时才设置key的value
  
42 # - XX :只有key存在时才设置key的value
  
43
  
44 SET key value PX milliseconds
  
45 SET key value EX seconds NX   
  
46 SET key value XX
  
47
  
48 # 只有key不存在时才设置,和 `SET key value NX`效果一样
  
49 SETNX key value
  
50
  
51 # 重写key对应value的一部分
  
52 SETRANGE key offset value
  
53
  
54 # 获取key对应value的长度
  
55 STRLEN key
  
56
  
57 # 根据key删除缓存中的值
  
58 DEL key
  
59
  
60 # integer 类型的值减一
  
61 DECR key
  
62
  
63 # integer 类型的值减小 decrement
  
64 DECRBY key decrement
  
65
  
66 # integer类型的值加一
  
67 INCR key
  
68
  
69 # integer 类型的值减小 increment
  
70 INCRBY key increment
  


更多 key 操作
  

1 # 以秒为单位设置key过期时间  
2 EXPIRE key seconds
  
3
  
4 # 以秒为单位设置key过期时间的UNIX时间戳
  
5 EXPIREAT key timestamp
  
6
  
7 # 以毫秒为单位设置key过期时间
  
8 PEXPIRE key milliseconds
  
9
  
10 # 以毫秒为单位设置key过期时间的UNIX时间戳
  
11 PEXPIREAT key milliseconds-timestamp
  
12
  
13 # 移动key到另外一个database
  
14 MOVE key db
  
15
  
16 # 移除key的过期时间,设置为不过期
  
17 PERSIST key
  
18
  
19 # 获取key的剩余生存时间单位为秒,还有多长时间过期单位为秒
  
20 TTL key
  
21
  
22 #返回值说明
  
23 # -2:key不存在
  
24 # -1:key存在但是没有设置过期时间
  
25
  
26 # 获取key的剩余生存时间单位为毫秒,还有多长时间过期单位为毫秒
  
27 PTTL key
  
28
  
29 # 获取一个随机生成的 key
  
30 RANDOMKEY
  
31
  
32 # 重命名一个 key
  
33 RENAME key newkey
  
34
  
35 # 获取key存储的value的数据类型
  
36 TYPE key
  
37
  
38 # list 或 set 排序
  
39 SORT key
  


更多命令
  更多参考 https://redis.io/commands

远程 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*
  



[*]  找到自己要的key,复制完整key名称,如果返回 (empty list or set),则说明不存在这样的key,检查你的模式是否正确,如果正确说明并没有你想要的key

[*]  根据key查询value

  

get key  



[*]手动更新key的value
  

set key value   



[*]删除key
  

del key  


More

redis客户端
  redis有丰富的客户端支持,如果想要获取一个完整的列表,可以访问这里 https://redis.io/clients

redis 命令
  redis 命令集合 https://redis.io/commands

reids 文档
  redis 官方文档 https://redis.io/documentation

redis 下载
  redis 下载


[*]linux : https://redis.io/download
[*]windows : https://github.com/MSOpenTech/redis/releases
End
  想不起来写点什么好了,想起来再写吧,有什么问题或疑问欢迎可以随时和我联系 weihanli@outlook.com
页: [1]
查看完整版本: redis 介绍和常用命令