redis 的笔记

redis 的笔记

  • 什么是redis
    redis是开源免费的,支持互联网,可基于内存也可以持久化的key-value数据库
  • 安装redis
wget https://download.redis.io/releases/redis-6.2.1.tar.gz
# 解压到指定文件夹
tar xzf redis-6.2.1.tar.gz
# 进入目录
cd redis-6.2.1
# 编译
make
  • 启动redis
# 在启动redis服务src/redis-server
# 启动服务后可以按ctrl+c,停止服务
./src/redis-server
  • 使用客户端redis
# 启动redis服务端
redis-cli
  • redis数据结构 – 简介

    redis是一种高级的key:value存储系统,其中value支持五种数据类型

字符串(strings)
字符串列表(lists)
字符串集合(sets)
有序字符串集合(sorted sets)
哈希(hashes)

  • redis数据结构 – strings
    strings是一种常见的字符串类型,也是任何存储系统的基本数据类型
127.0.0.1:6379> set mystr "hello Wold"
OK
127.0.0.1:6379> get mystr
"hello Wold"
且字符串是二进制,安全的,可以保存图片文件内容作为二进制来存储
# 可以通过字符串类型进行数值操作
127.0.0.1:6379> set mynum "2"
OK
127.0.0.1:6379> get mynum
"2"
# 进行加法
127.0.0.1:6379> incr mynum
(integer) 3
127.0.0.1:6379> get mynum
"3"
# decr进行减法
127.0.0.1:6379> decr mynum
(integer) 2
127.0.0.1:6379> get mynum
"2"
  • redis数据结构 – lists

lists的底层不是数组,而是链表。也就是说在大数据的情况下,在头部和尾部插入一个新元素,复杂度是常数级别的,比如lpush在10个元素的lists头部插入新元素,和大数据的情况下lists头部插入新元素速度也是一样的。

lists的常用操作包括LPUSH、RPUSH,LRANGE等。我们可以在LPUSH的lists的头部插入一个新元素,用LRANGE命令从lists中制定一个范围来提取元素

# 创建一个lists,在左侧插入一个元素“1”
127.0.0.1:6379> LPUSH mylist "1"
(integer) 1
# 在lists的右侧插入一个元素“2”
127.0.0.1:6379> RPUSH mylist "2"
(integer) 2
# 在左侧插入一个“0”
127.0.0.1:6379> LPUSH mylist "0"
(integer) 3
# 表示从头部的第一个到第二个的数值
127.0.0.1:6379> LRANGE mylist 0 1
1) "0"
2) "1"
# 表示从头部的第一个到尾部的数值
127.0.0.1:6379> LRANGE mylist 0 -1
1) "0"
2) "1"
3) "2"

lists的应用相当广泛,例如:
1、可以利用lists来实现一个消息队列,而且可以确保先后顺序,不必要像mysql使用order by来排序。
2、利用LRANGE还可以很方便实现分页查询。
3、在博客系统中,每片博文的评论也可以存在一个单独的list中。

  • redis数据结构–集合

redis的集合是一种无序的集合,无先后顺序排序。
集合的元素有很多操作,如:添加新元素,删除已经有的元素,取交集、取并集、取差集等。

# 向集合myset中添加一个新元素
127.0.0.1:6379> sadd myset "one"
(integer) 1
127.0.0.1:6379> sadd myset "two"
(integer) 1
# 遍历集合myset的所有元素
127.0.0.1:6379> smembers myset
1) "two"
2) "one"
# 判断元素one是否在集合myset中,返回1表示存在
127.0.0.1:6379> sismember myset "one"
(integer) 1
# 判断元素three是否在集合myset中,返回0表示不存在
127.0.0.1:6379> sismember myset "three"
(integer) 0
# 新建一个新的集合yourset
127.0.0.1:6379> sadd yourset "1"
(integer) 1
127.0.0.1:6379> sadd yourset "2"
(integer) 1
127.0.0.1:6379> smembers yourset
1) "1"
2) "2"
# 对两个集合并并集
127.0.0.1:6379> sunion myset yourset
1) "two"
2) "one"
3) "2"
4) "1"

对于集合的使用也有一些常用的方式,比如,qq有一个社交功能叫做“好友标签”,大家可以给你的好友贴标签,比如“大美女”、“土豪”、“欧巴”等等,这时就可以使用redis的集合来实现,把每一个用户的标签都存储在一个集合之中。

  • redis数据结构-有序集合
# 新增一个有序集合myzset,并加入一个元素baidu.com,给他赋予的序号是1
127.0.0.1:6379> zadd myzset 1 baidu.com
(integer) 1
# 向myzset中新增一个元素360.com,赋予他的序号是3
127.0.0.1:6379> zadd myzset 3 360.com
(integer) 1
# 向myzset中新增一个元素google.com,赋予他的序号是2
127.0.0.1:6379> ZADD myzset 2 google.com
(integer) 1
# 遍历所有的序号和元素内容
127.0.0.1:6379> zrange myzset 0 -1 withscores
1) "baidu.com"
2) "1"
3) "google.com"
4) "2"
5) "360.com"
6) "3"
# 只列出元素
127.0.0.1:6379> ZRANGE myzset 0 -1
1) "baidu.com"
2) "google.com"
3) "360.com"
  • redis数据结构-哈希

哈希是从redis-2.0.0版本之后才有的数据结构。
hashes存的是字符串和字符串值之间的映射,比如一个用户要存储其全名、姓氏、年龄等等,就很适合使用哈希。

# 建立哈希值,并赋值
127.0.0.1:6379> HMSET user:001 username antires password P1pp age 34
OK
# 列出哈希的内容
127.0.0.1:6379> HGETALL user:001
1) "username"
2) "antires"
3) "password"
4) "P1pp"
5) "age"
6) "34"
# 修改某一个哈希值,0表示更新成功,1表示更新失败
127.0.0.1:6379> HSET use3:001 password 1234
(integer) 0
# 再次遍历发现已经更新
127.0.0.1:6379> HGETALL user:001
1) "username"
2) "antires"
3) "password"
4) "1234"
5) "age"
6) "34"
# 获取哈希值的一个password值
127.0.0.1:6379> hget user:001 password
"1234"
  • redis持久化-两种方式
    redis提供了两种持久化的方式,分别是RDB(Redis Database) 和 AOF(Append Only File)。
    RDB,简而言之,就是在不同的时间点,将redis存储的数据生成快照并存储到磁盘等介质上。
    AOF,则是换了一个角度来实现持久化,那就是将redis执行过的所有指令记录下来,在下次redis重新启动时,只能把这些指令从前到后在重复执行一遍,就可以实现数据恢复了。
    其实RDB和
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值