Redis学习笔记(1)
Redis学习笔记(1)

Redis学习笔记(1)

Redis是一个开源的基于内存的键值对数据库,是非关系数据库。

特征:

  • 基于内存,读写速度极快,可以处理大量读写请求。
  • 支持多种数据结构。
  • 支持主从复制,提供数据冗余和故障恢复能力。
  • 支持持久化,可以将内存数据保存到磁盘中。
  • 支持事务,一次执行多个命令。
  • 丰富的功能,可用于缓存,消息队列等场景。

主要应用场景:

  • 缓存常见的使用常见,比如缓存查询结果,热点数据等。大大降低了数据库负载。
  • 处理大量的读写请求,比如访问统计,消息队列等。
  • 排行榜,计数器等功能。
  • 分布式锁等。

安装Redis

下载Redis,linux是正统,但是window的可以到github上找微软开源了的,下载后解压,到目录命令行去执行”redis-server redis.windows.conf”开启redis服务。

由于每次都需要打开窗口并保持命令行窗口开启,我们就将服务设置成window下的服务,还是刚刚的目录,执行”redis-server –service-install redis.windows-service.conf –loglevel verbose”

然后在Redis目录下启动redis:”redis-server –service-start”

不过这里我产生了一个问题,显示fail to start,然后去查询服务,在windows服务面板启动也报错,显示1067错误。只需要在Redis目录下创建Logs文件夹,文件夹里创建”redis_log.txt”就可以了,我看了一下,应该是日志文件,因为找不到日志文件,就无法开启。这个应该算是微软开源Windows的redis时的小错误吧,这个文件忘记创建了。

开启服务后就可以访问这个数据库了。访问命令:redis-cli -h 127.0.0.1 -p 6379

redis常见数据结构

  • String:字符串
  • Hash:哈希表
  • List:链表
  • set:不可重复的集合
  • sortedSet:排序后的不可重复集合
  • 特殊类型:
    • GEO:地理坐标
    • BitMap
    • HyperLog

常见命令

  • KEYS:查看符合模板的所有key
  • DEL:删除一个指定的key
  • EXISTS:判断key是否存在
  • EXPIRE:给一个key设置有效期,到期会自动删除key
  • TTL:查看一个key的剩余有效期

Redis允许分层存储,类似文件夹的方式,路径用”:”分号隔离。set hangzhou:xihuqu wjq

并且允许存储JSON格式的数据:set user:3 ‘{“id”: 1, “name”: “jack”, “age”: 21}’

String常见命令

  • SET KEY VAL:插入键为key,值为VAL的键值对
  • GET KEY:查找键为key的值
  • MSET:批量添加多个String变量的键值对
  • MGET:根据多个key获取多个String类型的value
  • INCR:让一个整型的key自增1
  • INCRBY:让一个整型的key自增指定步长
  • INCRBYFLOAT:让一个浮点类型的数字自增指定步长
  • SETNX:添加一个String类型的键值对,如果这个key存在,则不执行
  • SETEX:添加一个String类型的键值对,并指定有效期

Hash类型

我的理解是String类型是map<String,String>,而Hash类型是map<String,map<String,String>>。Hash在key值指向的是field,再要通过field找到最后的value。

Hash常见命令:

  • HSET key field value:添加或者修改hash类型key的field的值
  • HGET key field:获取一个hash类型的key的field的值
  • HMSET:批量添加多个值
  • HMGET:批量获取多个值
  • HGETALL:获取一个hash类型key中的所有field和value
  • HKEYS:获取一个hash类型的key中的所有field
  • HVALS:获取一个hash类型的key中的所有value
  • HINCRBY:让一个hash类型key的字段自增并指定步长
  • HSETNX:添加一个hash类型的key的field值,如果存在,则不执行。

List类型

Redis中的List类型和java中的LinkedList类似,可以看作一个双向链表结构,支持正向检索和反向检索。

特征:

  • 有序
  • 元素可以重复
  • 插入和删除快
  • 查询速度一般

List常见命令:

  • LPUSH key element … :向列表左侧插入一个或多个元素
  • LPOP key :移除并返回列表最左侧的第一个元素,如果没有则返回nil
  • RPUSH key element … :向列表右侧插入一个或多个元素
  • RPOP key:移除并返回列表最右侧的第一个元素,如果没有则返回nil
  • LRANGE key star end:返回一段坐标范围内的所有元素
  • BLPOP和BRPOP:与RPOP和LPOP类似,只是如果没有元素,则等待指定时间再返回,而不是直接返回nil

Set类型

Redis的Set结构和java中的HashSet类型。

特征:

  • 无序
  • 元素不可重复
  • 查找快
  • 支持交集,并集,差集等功能

Set类型的常见命令:

  • SADD key member … :向set中添加一个或多个元素
  • SREM key member … :从set中删除一个或多个元素
  • SCARD key:返回set中元素的个数
  • SISMEMBER key member :判断一个元素是否存在于set中
  • SMEMBERS:获取set中的所有元素
  • SINTER key1 key2 …:求多个key的交集
  • SDIFF key1 key2 …:求多个key的差集
  • SUNION key1 key2 …:求多个key的并集

SortedSet类型

Redis的SortedSet是一个可排序的set集合。每个元素都带有一个score属性,用来进行排序,底层实现是一个跳表(SkipList)加hash表。

特征:

  • 可排序
  • 元素不可重复
  • 查找快

SortedSet类型的常见命令:

  • ZADD key score member … :添加一个或多个元素到sortedset,如果已经存在,则更新值
  • ZREM key member :从sortedset中删除一个元素
  • ZSCORE key member:返回sorted set中的指定元素的score值
  • ZRANK key member :获取sorted set中的指定元素的排名
  • ZCARD key:获取sorted set 中的元素个数
  • ZCOUNT key min max:统计score值再给定范围内的所有元素个数
  • ZINCRBY key increment member:让sorted set 中的指定元素自增指定步长(increment值)
  • ZRANGE key min max:按照score排序后,获取指定排名范围内的元素
  • ZRANGEBYSCORE key min max:按照score排序后,获取指定score范围内的元素
  • ZDIFF,ZINTER,ZUNION:求差集,交集,并集

发表回复

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