【Redis 5种数据类型、RDB/AOF、集群、哨兵、缓存穿透、击穿和雪崩】进阶(上)

本文涉及的产品
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
简介: 【Redis 5种数据类型、RDB/AOF、集群、哨兵、缓存穿透、击穿和雪崩】进阶(上)

一、Redis安装


1.1 WIndows下安装


1.WIN下载地址:https://github.com/microsoftarchive/redis/releases/tag/win-3.2.100

2.下载完毕后,解压到工作目录。

3.双击运行服务 redis-server

4.双击客户端 redis-cli


20200802104352852.png


1.2 Linux下安装


1.下载地址:https://redis.io/ ,注意版本号更高的版本需要更高的GCC版本

2.redis-5.0.8.tar.gz

3.上传服务器linux

4. tar -zxvf redis-5.0.8.tar.gz

5. yum install gcc-c++

6. cd redis-5.0.8 -> make && make install

7. 默认redis的安装路径为 : /usr/local/bin

8. 创建redis的配置目录: mkdir /usr/local/bin/redisconf

9. 复制配置文件: cp /home/redis-5.0.8/redis.conf /usr/local/bin/redisconf

10.可以修改为后台启动:vim redis.conf -->daemonize yes

10. 指定配置文件启动redis服务:redis-server /usr/local/bin/redisconf/redis.conf

11. 连接服务:redis-cli -p 6379

12. 关闭服务:shutdown --> exit


1.3 Redis性能测试工具


redis-benchmark

1.测试:100个并发连接,每个并发100000个请求

redis-benchmark -h localhost -p 6379 -c 100 -n 100000


2020080211212521.png

1.4 基础知识


redis默认有 16 个数据库,默认使用第 0 个数据库。

切换数据库:select 3

查看所有的数据K: keys *

清空当前数据库:flushdb,清除所有数据库:flushall

redis为单线程的。基于内存操作。性能瓶颈为机器内存和网络带宽。

多线程CPU切换轮转【耗时间】,上下文切换,不一定比单线程快。

redis所有的数据全部在内存中,单线程效率最高。


二、五大数据类型


2.1 String 类型


设置 set key1 1www

获取get key1

追加 append key “oooo”

获取长度 STRLEN key1

自增 浏览量

set views 0

incr views 自增1

decr views 自减1

incr views 2 设置自增2

对象 : set user:1 {name:wang,age:24}

mset user:1:name wang user:1:age 24

mget user:1name user:1:age


2.2 List类型【栈,队列,阻塞队列】


LPUSH list one 多个值插入到列表的头部

LRANGE list 0 -1 通过区间拿到所有的值

LRANGE list 0 1 通过区间拿到所有的值

Rpush list three 插入队列的尾部

Lpop list 移除左侧第一个值

Rpop list 移除右侧第一个值

lindex list 1 通过瞎做获取值

Llen list 得到列表的长度

Lrem list 1 one 移除一个或者多个指定的值

ltrim list 1 2 从1-2截断下来

lset list 0 kkk ;列表指定下标的值更新为另外一个值


2.3 Set类型


Set中的值是不可以重复的

sadd myset “hello” 添加一个值

SMEMBERS myset 查看某个集合的元素

SISMEMBER myset hello 判断某一个元素是否在这个集合中

scard myset 获取Set集合的个数

srem myset hello 移除某一个值

SRANDMEMBER myset 随机取出一个元素

spop myset 随机移除一个元素

SDIFF key1 key2 差集

SINTER key1 key2 交集

SUNION key1 key2 并集


2.4 Hash类型


Map集合,key-map,值是一个map集合,和String类型差不多

更适合对象的存储


hset myhash field1 wangyin 存储一个值

hget myhash field1 取出一个值

hmset myhash field1 hello field2 word 存储多个k-v值

hmget field1 field2 获得多个值

hgetall myhash 取出所有字段值

hdel myhash field1 删除指定的key字段,对应的value也被删除了

hlen myhash 集合长度

hkeys myhash 获取所有的key

hvals myhash 获取所有的值

hset user:1 name wangyi 存储对象属性值

hget user:1 name 获取对象属性值


2.5 Zset类型


在set的基础之上,增加了一个值 ,set k1 v1 zset k1 score v1


zadd myset 1 one 1 为排序

zadd salary 1000 xiaoming

zadd salary 2000 xiaohong

zadd salary 3000 xiaowang

ZRANGEBYSCORE salary -inf +inf 所有的字段升序排序

ZRANGEBYSCORE salary 0 -1 所有的字段降序排序

ZRANGESCORE salary -inf 2500 withscores 查出所有在2500以内带有分数和名字降序排列

zrange salary 0 -1 查询所有

zrem salary xiaohong 移除一个元素

zscard salary 获取有序集合中的个数


三、特殊数据类型


3.1 Geospatia地理位置


朋友定位,附近的人,打车距离查询


规则:两级数据无法导入,一般通过java批量导入

参数 key 值(经度,维度,名称)

redis在redis3.2之后就推出了,计算地理位置信息,两地距离


geoadd china:city 116.40 39.90 beijing 添加地理位置信息

geoadd china:city 121.47 31.23 shanghai

geoadd china:city 106.50 29.53 chongqing

geoadd china:city 114.05 22.54 guangdong

geoadd china:city 120.16 30.24 hangzhou

geoadd china:city 108.96 34.26 xian

geopos china:city beijing xian 获取指定城市的地理位置

geodist china:city beijing shanghai 默认直线距离单位m

geodist china:city beijing shanghai km 单位为km


附近的人?获取所有的地址 ,通过半径来查询定位


4. georadius china:city 110 30 1000 km 维度 查询附近1000km的城市

5. georadius china:city 110 30 1000 km withdist withcoord count 1 周围人定位信息限定数量1


3.2 Hyperloglog 基数统计


不重复的元素的个数,可以接受误差0.81%

优点:占用的内存是固定的,只需要12K的内存。


页面的访问量【UV】,一个人访问一个网站多次,算作一个人。

传统的方式:Set保存用户ID,如果大量的话,比较麻烦,目的为了计数,而不是保存用户ID。


PFadd mykey a b c d e f g h i h 存储

PFCOUNT mykey 计算基数数量

PFMERGE mykey mykey2 合并


3.3 Bitmap 位图场景


只有0和1,两个状态,操作二进制位


统计疫情感染人数: 0 1 0 1 0 0 0 1

统计同户信息,活跃,不活跃,登录, 不登录, 打卡

356天 = 365 bit 46byte足够


测试只有1-周末的打卡记录:周一:1 周二:0


setbit sign 0 1

setbit sign 1 0

setbit sign 2 1

setbit sign 3 1

setbit sign 4 0

getbit sign 3 查看周三有没有打卡

bitcount sign 打卡天数

bitcount sign 0 3 统计周一到周四的打卡记录天数


四、redis事务操作


1.ACID:要么一起成功,要么一起失败。

2.redis单条命令保证原子性,但是事务不保证原子性 ,所有的命令就会被序列化,会按照顺序执行。

3.redis事务没有隔离级别的概念,所有的命令在事务中,没有直接被执行。

4.**redis的事务:**开启事务【multi】–>命令入队【…】–>执行事务【exec】


20200803085819268.png


5.DISCARD:取消事务


五、redis乐观锁


5.1 悲观锁


很悲观,认为什么时候都会出现问题


5.2 乐观锁


1.很乐观,认为神魔时候都不会出现问题,不会上锁,更新数据的时候会比较一下这个期间是否有人修改过。

2.获取版本号

3.更新时候比较version

如:

set money 100

set out 0

watch money 监控监事测试

multi 开启事务

DECRBY money 20 减少20

INCRBY out 20 增加20

exec 执行事务


六、Jedis 客户端


6.1 maven项目添加pom

         <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>3.2.0</version>
         </dependency>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.66</version>
    </dependency>


6.2 连接测试

public class TestJedis{
  public static void main(String[] args){
    Jedis jedis = new Jedis("127.0.0.1",6379);
    // 所有的方法全部在jedis中
    .........
    JSONObject jsonObject = new JSONObject();
    jsonObject.put("hello","world");
    jsonObject.put("name","reba");
    // 事务
    Transaction multi = jedis.multi();
    String result = jsonObject.toJSONString();
    try{
      multi.set("user1",result);
      multi.set("user2",result);
      int i = 1/0; // 模拟异常
      multi.exec(); // 执行事务
    }catch(...){
      multi.discard(); // 放弃事务
    }finally{
      jedis.close(); // 关闭连接
    }
  }
}


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
26天前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
这篇文章是关于如何在SpringBoot应用中整合Redis并处理分布式场景下的缓存问题,包括缓存穿透、缓存雪崩和缓存击穿。文章详细讨论了在分布式情况下如何添加分布式锁来解决缓存击穿问题,提供了加锁和解锁的实现过程,并展示了使用JMeter进行压力测试来验证锁机制有效性的方法。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
|
20天前
|
缓存 NoSQL Linux
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
|
26天前
|
NoSQL 安全 Java
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
这篇文章深入探讨了Redis中的String数据类型,包括键操作的命令、String类型的命令使用,以及String在Redis中的内部数据结构实现。
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
|
26天前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
这篇文章介绍了如何在SpringBoot项目中整合Redis,并探讨了缓存穿透、缓存雪崩和缓存击穿的问题以及解决方法。文章还提供了解决缓存击穿问题的加锁示例代码,包括存在问题和问题解决后的版本,并指出了本地锁在分布式情况下的局限性,引出了分布式锁的概念。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
|
14天前
|
运维 监控 NoSQL
【Redis】哨兵(Sentinel)原理与实战全解~炒鸡简单啊
Redis 的哨兵模式(Sentinel)是一种用于实现高可用性的机制。它通过监控主节点和从节点,并在主节点故障时自动进行切换,确保集群持续提供服务。哨兵模式包括主节点、从节点和哨兵实例,具备监控、通知、自动故障转移等功能,能显著提高系统的稳定性和可靠性。本文详细介绍了哨兵模式的组成、功能、工作机制以及其优势和局限性,并提供了单实例的安装和配置步骤,包括系统优化、安装、配置、启停管理和性能监控等。此外,还介绍了如何配置主从复制和哨兵,确保在故障时能够自动切换并恢复服务。
|
26天前
|
存储 NoSQL 算法
Redis6入门到实战------ 三、常用五大数据类型(列表(List)、集合(Set)、哈希(Hash)、Zset(sorted set))
这是关于Redis 6入门到实战的文章,具体内容涉及Redis的五大数据类型:列表(List)、集合(Set)、哈希(Hash)、有序集合(Zset(sorted set))。文章详细介绍了这些数据类型的特点、常用命令以及它们背后的数据结构。如果您有任何关于Redis的具体问题或需要进一步的帮助,请随时告诉我。
|
21天前
|
存储 缓存 NoSQL
【Azure Redis 缓存 Azure Cache For Redis】如何设置让Azure Redis中的RDB文件暂留更久(如7天)
【Azure Redis 缓存 Azure Cache For Redis】如何设置让Azure Redis中的RDB文件暂留更久(如7天)
|
23天前
|
存储 NoSQL Redis
Redis 文件总大小问题之计算待加载AOF文件总大小如何解决
Redis 文件总大小问题之计算待加载AOF文件总大小如何解决
|
22天前
|
消息中间件 存储 NoSQL
redis实战——go-redis的使用与redis基础数据类型的使用场景(一)
本文档介绍了如何使用 Go 语言中的 `go-redis` 库操作 Redis 数据库
redis实战——go-redis的使用与redis基础数据类型的使用场景(一)
|
23天前
|
NoSQL Redis
Redis AOF重写问题之减少CPU和fork开销如何解决
Redis AOF重写问题之减少CPU和fork开销如何解决