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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 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 关系型数据库
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
本文详解缓存雪崩、缓存穿透、缓存并发及缓存预热等问题,提供高可用解决方案,帮助你在大厂面试和实际工作中应对这些常见并发场景。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
|
28天前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
35 1
|
1月前
|
存储 缓存 监控
利用 Redis 缓存特性避免缓存穿透的策略与方法
【10月更文挑战第23天】通过以上对利用 Redis 缓存特性避免缓存穿透的详细阐述,我们对这一策略有了更深入的理解。在实际应用中,我们需要根据具体情况灵活运用这些方法,并结合其他技术手段,共同保障系统的稳定和高效运行。同时,要不断关注 Redis 缓存特性的发展和变化,及时调整策略,以应对不断出现的新挑战。
64 10
|
1月前
|
缓存 监控 NoSQL
Redis 缓存穿透的检测方法与分析
【10月更文挑战第23天】通过以上对 Redis 缓存穿透检测方法的深入探讨,我们对如何及时发现和处理这一问题有了更全面的认识。在实际应用中,我们需要综合运用多种检测手段,并结合业务场景和实际情况进行分析,以确保能够准确、及时地检测到缓存穿透现象,并采取有效的措施加以解决。同时,要不断优化和改进检测方法,提高检测的准确性和效率,为系统的稳定运行提供有力保障。
50 5
|
1月前
|
缓存 监控 NoSQL
Redis 缓存穿透及其应对策略
【10月更文挑战第23天】通过以上对 Redis 缓存穿透的详细阐述,我们对这一问题有了更深入的理解。在实际应用中,我们需要根据具体情况综合运用多种方法来解决缓存穿透问题,以保障系统的稳定运行和高效性能。同时,要不断关注技术的发展和变化,及时调整策略,以应对不断出现的新挑战。
48 4
|
7月前
|
NoSQL 关系型数据库 MySQL
Redis持久化机制 RDB 和 AOF 的选择
Redis持久化机制 RDB 和 AOF 的选择
102 0
|
2月前
|
存储 缓存 NoSQL
大数据-45 Redis 持久化概念 RDB AOF机制 持久化原因和对比
大数据-45 Redis 持久化概念 RDB AOF机制 持久化原因和对比
42 2
大数据-45 Redis 持久化概念 RDB AOF机制 持久化原因和对比
|
3月前
|
存储 缓存 NoSQL
Redis中的rdb和aof
本文深入探讨了Redis的持久化机制,包括RDB和AOF两种方式。详细解释了RDB的工作原理、优势和劣势,以及AOF的实现原理、配置选项、文件重写机制和三种数据同步方式,还介绍了AOF文件修复工具redis-check-aof的使用,并通过实例展示了如何开启和配置AOF持久化方式。
Redis中的rdb和aof
|
2月前
|
存储 缓存 NoSQL
大数据-46 Redis 持久化 RDB AOF 配置参数 混合模式 具体原理 触发方式 优点与缺点
大数据-46 Redis 持久化 RDB AOF 配置参数 混合模式 具体原理 触发方式 优点与缺点
66 1
|
3月前
|
存储 NoSQL Redis
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
Redis持久化、RDB和AOF方案、Redis主从集群、哨兵、分片集群、散列插槽、自动手动故障转移
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群