redis介绍
NOSQL
非关系型的数据库,分为四类
- 健值存储数据库,使用一个哈希表,该表中有一个特定的键和一个指针指向特定的数据,例如 Redis
- 列存储数据库,该部分数据库通常是用应对分布式存储的海量数据,键仍然存在,但是它们的特点是指向了多个列,例如 HBase
- 文档型数据库,该类型的数据模型是版本化的文档,半结构化的文档以特定的格式存储,比如JSON。文档型数据库可以看作是健值数据库的升级版本,允许之间嵌套健值,而且文档型数据库比健值数据库的查询效率更高,例如 MongoDB
- 图形数据库
1.x 主从模式 / 2.x 哨兵模式 / 3.x 集群模式
安装部署 redis
- 解压
cd /usr/local/redis/
- 编译
make
- 进入src下安装
cd /usr/local/redis/src && make install
- 修改配置文件
vim /usr/local/redis/reids.conf
- bind 当前ip地址、daemonize 改为yes (后台守护进程)
- 日志文件名设置,全路径(目录不存在时,需要创建目录)
- 数据文件存储目录设置,全路径(目录不存在时,需要创建目录)
- 启动redis服务
/usr/local/bin/redis-server /usr/local/redis/redis.conf
- 启动redis客户端
/usr/local/bin/redis-cli -h ip地址 -p 端口(默认6379)
- 关闭redis服务
/usr/local/bin/redis-cli -h ip地址 -p 端口(默认6379) shutdown
可视化管理redis
下载安装 redisdesktop manager
redis基础数据类型
分为五种: String Hash List Set ZSet
-
info
获取redis信息 -
FLUSHALL
清除数据库
String
key里面,多个字段用冒号 :
分隔
- set key value # 设置健值
- get key # 获取键的值,没有时返回 nil
- setnx key value # key不存在进行设置,存在则不能设置
- setex key time value # 设置key在time秒之后值value过期
- setrange key index value # 替换key的index下标处开始替换值为value,多的用空格添加
- mset key1 value1 key2 value2 # 可以设置多个健值
- mget key1 key2 # 可以获取多个键的值
- getset key anothervalue # 设置键的新值,并返回其旧值
- type key # 返回键的类型,即使为数字,返回也是string
- incr key # 键的值加1
- decr key # 键的值减1
- incrby key step # 键的值加step步长
- decrby key step # 键的值减step步长
- append key value # 在键后面追加值
- strlen key 获取键的值的长度
Hash
Hash类型是String类型的field和value的映射表,或者说一个String集合。
它的特点特别适合存储对象,相比较而言,将一个对象类型存储在hash类型要比存储在string类型中要节省空间且方便
- hset hashkey field1 value1 # 设置hashkey对象,其中字field1属性的值为value1
- hget hashkey field1 # 返回hashkey对象的属性field1的值
- hmset / hmget # 类似于 mset / mget
- hsetnx # 类似于 setnx
- hincrby # 集合递增,没有 hdecrby
-hincrbyfloat # 浮点数加法 - hexists # 是否存在key 如果存在返回1,否则返回0
- hlen # 返回hash集合里的所有键的数量
- hdel # 删除指定hash的field
- hkeys # 返回hash里的所有的字段
- hvals # 返回hash的所有value
- hgetall # 返回hash里所有的key和value
List
List是一个链表结构的集合,其主要功能有push/pop 获取元素。
List是一个双端链表的结构,可以通过相关操作进行集合的头部或者尾部添加删除元素,list的设计非常简单精巧,既可以做栈,也可以做队列。
- lpush 从头部加入元素(栈)FILO
lpush list1 'hello'
lpush list1 'world' # list1 为栈(头---尾) ['world', 'hello']
lrange list1 0 -1 # 表示从头取到末尾 ['world', 'hello']
- rpush 从尾部加入元素(队列) FIFO
rpush list2 'jshan'
rpush list2 'liu' # list2 为队列(头---尾) ['jshan', 'liu']
lrange list2 0 -1 # 表示从头取到末尾 ['jshan', 'liu']
- linsert 插入元素
linsert list3 before [集合的元素] [插入的元素] # 复杂度为 O(n)
- lset 将指定下标的元素替换为指定的值
lset list4 0 b # 表示将最0个元素(最左边的元素)的值改为b
- lrem 删除元素,并返回删除元素的个数
lrem list4 0 b # 表示删除所有值为b的元素
lrem list4 1 b # 表示从左边删除1个值为b的元素
lrem list4 -1 b # 表示从右边删除1个值为b的元素
- ltrip 保留指定key的值范围内的数据
ltrip list4 2 3 # 表示保留list4中下标为 2到3 范围内的数据
- lpop 从list的头部删除元素,并返回删除元素的值
- rpop 从list的尾部删除元素,并返回删除元素的值
- rpoplpush 第一步从尾部删除元素,第二步将第一步的返回结果加入到头部
- lindex 获取list中指定index位置的元素
lindex list4 1
- llen 返回元素的个数
Set
set集合是string类型的无序集合,set是通过hashtable实现的,对集合我们可以取交集、并集、差集。
- sadd 向名称为key的set中添加元素
- spop 从set中随机弹出一个元素
- srandmember 从set中随机获取一个元素,不弹出(但是需要明白这里的随机原理,是将set中元素值先hash到不同的bulk中,可能有些bulk中值较多,有些较少,随机的时候先随机获取一个bulk,然后再从该bulk中随机获取元素)
- smembers 获取set中的所有元素
- sismember 判断某元素是否为集合元素,存在集合中刚返回1,否则返回0
- scard # 查看集合中元素个数
- smove set1 set2 item # 表示从集合set1中移除元素item到集合set2中,相当于先对set1执行spop,然后对set2执行sadd
- sinter set1 set2 # 获取set1和set2的交集
- sunion set1 set2 # 获取set1和set2的并集
- sdiff set1 set2 # 获取set1和set2的差集
- sinterstore / suionstore / sdiffstore 功能和 sinter / sunion / sdiff 相同,只是将返回结果存储在一个新的变量,例如
sinterstore setinter set1 set2 # 表示将set1和set2的交集存储在setinter
Zset
zset是有序集合,zadd向有序集合添加一个元素,该元素会重新调整该有序集合的元素排列顺序,也就是更新该集合。
- zadd zset1 value1 key1 value2 key2 # 在zset1中添加key1和key2,这两个的顺序按照对应的value来进行排序
- zrange zset1 0 -1 # 显示zset1中的所有key
- zrange zset1 0 -1 withscores # 显示zset1中的所有key和value(score)
- zrem 删除名称为key的zset中的元素
- zincrby 以指定值去自动递增或减少
- zrangebyscore # 找到指定区间范围的数据进行返回
- zrevrangebyscore # 对zrangebyscore 的结果逆序展示
- zremrangebyrank # 根据排名(索引)来删除区间内的元素
- zremrangebyscore # 根据score(value)来删除区间内的元素
- zrank 返回排序索引(下标),排序方法是从小到大
- zcard 返回集合中所有元素的个数
- zcount 返回集合中score在指定区间内的元素个数
- zremrangebyrank 删除集合中下标区间内的元素
- zremrangebyscore 删除集合中score在指定区间内的元素