【Redis】Redis基础

Redis基础

初识Redis

认识NoSQL

SQL:结构化查询语言 => 关系型数据库

NoSQL:非关系型数据库

SQL与NoSQL的差异:

  1. 数据结构
    1. SQL结构化:表的信息依赖于表的结构
    2. NoSQL非结构化:存储的信息为KV形式
  2. 数据关联
    1. SQL关联:可以建立并维护表与表之间的关系(外键)
    2. NoSQL无关联:需要自行维护数据关联
  3. 查询方式
    1. SQL:使用SQL语句查询
    2. NoSQL:没有统一标准(Redis、MongoDB)
  4. 事物特性
    1. SQL:满足ACID
    2. NoSQL:基本可用BASE
  5. 存储方式
    1. SQL:磁盘
    2. NoSQL:内存(速度快)
  6. 扩展性
    1. SQL:垂直(本机)
    2. NoSQL:水平(支持分布式)

Redis特点

  1. KV结构
  2. 单线程,命令执行具备原子性
  3. 低延迟、性能快(基于内存、IO多路复用、C语言编写)
  4. 支持数据持久化
  5. 支持主从集群(扩展速度)、分片集群(扩展存储量)
  6. 支持多语言客户端

Redis安装

Redis官方只提供了Linux版本

Redis常见命令

Redis通用命令

KEYS:查看符合模板的所有key

不建议在生产环境(或集群的主节点)上使用。Redis单线程,会导致线程阻塞。

KEYS *name*

DEL:删除key

DEL username

DEL username password

EXISTS:判断key存在

EXISTS username

EXPIRE:给key设置有效期,单位是秒(到期自动删除)

TTL:查看有效期(-2表示不存在、-1表示永不过期)

EXPIRE name 20

TTL name

Redis数据结构

  1. String
  2. Hash(类似JSON)
  3. List(列表)
  4. Set(无重复元素的集合)
  5. SortedSet(有序集合)
  6. GEO(经纬度坐标)
  7. BitMap
  8. HyperLog
String

字符串,最简单的数据类型。上限是512M。

String的类型

  • string:字符串
  • int:整型,可以自增自减
  • float:浮点类型,可以自增自减

常见命令

  1. SET:添加、修改KV
  2. GET:通过K查询V
  3. MSET:批量添加
  4. MGET:批量查询
  5. INCR:整型i++(INCR age:age++)
  6. INCRBY:整型i+=n(INCRBY age 2:age += 2)
  7. INCRBYFLOAT:浮点i+=n(INCRBYFLOAT level 2:level += 2)
  8. SETNX:新增KV(若存在K则不添加)
  9. SETEX:添加KV,并指定有效期

key的结构:层级存储。用于key名称的设置,避免了key重复的问题

项目名:业务名:类型:id

hpan:user:username:1
hpan:admin:username:1
Hash

无序字典,类似JSON。

相比于序列化JSON,以字符串形式保存。Hash结构可以更方便地修改。

常见命令

  1. HSET key field value:添加、修改key的field值(HSET user:1 username wmh
  2. HGET key field:查询key的field值(HSET user:1 username
  3. HMSET、HMGET:批量
  4. HGETALL:查询所有的field和value
  5. HKEYS、HVALS:查询所有的field或value
  6. HINCRBY:整型value+=n(HINCRBY user:4 age 2:user[4].age+=2)
  7. HSETNX:新增field-value(若存在K则不添加)
List

双向链表,类似于LinkedList。可以正向、反向查找。

  1. LPUSH/RPUSH key value:左/右侧插入元素
  2. LPOP/RPOP key:左/右侧弹出元素
  3. LRANGE key i j:从i到j遍历元素
  4. BLPOP、BRPOP:阻塞式获取(有元素就取、没有元素就等)
  • 模拟栈:入口出口在同一边
  • 模拟队列:入口出口不在同一边
  • 模拟阻塞队列:入口出口不在同一边,出队使用BLPOP、BRPOP
Set

无序、元素不可重复、查找速度快、支持交集、并集、差集等。

单个Set:

  1. SADD key item…:添加item
  2. SREM key item…:移除item
  3. SCARD key:查询元素个数
  4. SISMEMBER key item:判断item是否存在
  5. SMEMBERS:获取所有元素

Set之间:

  1. SINTER k1 k2:交集
  2. SDIFF k1 k2:差集
  3. SUNION k1 k2:并集
SortedSet

每个元素都带一个score属性,根据score排序。可排序、元素不重复、查询速度快。

  1. ZADD key score item…:添加item
  2. ZREM key item…:移除item
  3. ZSCORE key item:查询item的score
  4. ZRANK key item:获取item的排名
  5. ZCARD key:查询元素个数
  6. ZCOUNT key min max:获取分数在min到max的元素个数
  7. ZRANGE key i j:获取排名为i到j的元素
  8. ZRANGEBYSCORE key min max:获取分数为min到max的元素
  9. ZINCRBY key n item:item.score+=n
  10. ZDIFF、ZINTER、ZUNION:差集交集并集

排名默认为升序,降序排名需要加上REV:ZRANK → ZREVRANK

Redis的Java客户端

客户端介绍

  1. Jedis:方法命名和Redis命令相似。线程不安全,多线程需要连接池。
  2. letture:基于Netty,支持同步、异步和响应式编程方式,线程安全。支持哨兵模式、集群模式和管道模式。
  3. Redisson:实现了分布式、可伸缩的Java数据结构。和使用原生集合一样使用Redis集合。

SpringDataRedis:整合了Jedis、letture

Jedis

redis/jedis: Redis Java client (github.com)

Jedis使用:

1、引入依赖

<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>5.0.0</version>
</dependency>

2、建立连接

Jedis jedis = new Jedis("localhost", 6379);
jedis.auth("123.com");
jedis.set("name", "wmhs");
jedis.close();

多线程 → 使用Jedis连接池

SpringDataRedis

简介

Spring Data Redis

  • 整合Lettuce和jedis
  • 提供了RedisTemplate统一API来操作Redis
  • 支持Redis的发布订阅模型、哨兵、集群
  • 支持基于Lettuce的响应式编程
  • 支持基于JDK、JSON、宇符串、Spring对象的数据序列化及反序列化
  • 支持基于Redis的DKCollection实现

SpringDataRedis中提供了RedisTemplate工具类,其中封装了各种对Redis的操作。

不同数据类型的操作API封装到了不同的类型中

自定义RedisSerializer

RedisTemplate可以接收Object作为值写入Redis。

But,采用JDK序列化Object为字节形式。占用内存大、可读性差。

So,可以自行编写RedisSerializer实现(使用jackson)。

But,写入的对象有@class属性,造成了额外开销。

StringRedisTemplate

Spring默认提供了一个StringRedisTemplate类,KV的序列化方式默认就是String方式。

如何存对象? → 自行序列化和反序列化

常见的JSON序列化库:

  1. gson(google 的)
  2. fastjson alibaba(阿里,快但是有Bug)
  3. jackson
  4. kryo

使用步骤:

1、导入pom.xml配置

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>    
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
</dependency>

2、配置application.yml

spring:
  data:
    redis:
      port: 6379
      host: 127.0.0.1
      password: 123456
      database: 0
      timeout: 10000
      lettuce:
        pool:
          enabled: true
          max-active: 100
          max-wait: 10000
          max-idle: 10
          min-idle: 1

3、编写测试类

不连接数据库启动SpringBoot项目

@SpringBootApplication(exclude= {DataSourceAutoConfiguration.class})
@Test
void StringRedisTemplateTest() {
    ValueOperations<String, String> ops = stringRedisTemplate.opsForValue();
    // name
    ops.set("name", "wmh");
    System.out.println("name: " + ops.get("name"));
    // yx
    ops.set("yx", gson.toJson(new User("yx", 18)));
    String yx = ops.get("yx");
    System.out.println("yx: " + gson.fromJson(yx, User.class));
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/331921.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Android NDK Crash信息收集捕获和日志异常定位分析(addr2line)

Android NDK 闪退日志收集与分析 我们在开发过程中,Android JNI层Crash问题或者我们引用的第三方.so库文件报错,都是一个比较头疼的问题。相对Java层来说,由于c/c++造成的crash没有输出如同Java的Exception Strace堆栈信息,所以定位问题也是个比较艰难的事情。 Google Br…

Nomogram文献分析:提取数据

前言 今天教大家如何分析Nomogram类型的文章&#xff0c;并使用我们开发的系统零代码提取数据。 系统地址&#xff1a;https://clinicaldata.fun/ 要分析的文章&#xff1a;https://pubmed.ncbi.nlm.nih.gov/36504658/ 。这是一篇典型的mimic-iii数据分析的套路&#xff0c;…

智能小程序开发项目步骤流程

快速开始 在开发小程序之前&#xff0c;请确保电脑上已经安装node运行环境。可前往Node.js官网(opens in a new tab)下载安装。智能小程序环境搭建和面板小程序一致&#xff0c;请参考面板小程序搭建环境指南。 开发小程序的流程&#xff1a; 使用涂鸦开发者 IoT 账号登录 T…

c语言-结构体内存对齐

文章目录 前言一、结构体内存对齐总结 前言 本篇文章介绍结构体内存对齐。 一、结构体内存对齐 定义两个结构体&#xff1a; struct S1 {char c1;int i;char c2; };struct S2 {char c1;char c2;int i; }; //输出结构体大小 int main() {printf("%u\n", sizeof(st…

未来能源转型之路:2023年第十三届中国国际储能大会启示录

在2023年第十三届中国国际储能大会上&#xff0c;全球各地的能源专家、学者和企业代表齐聚一堂&#xff0c;共同探讨了储能技术在推动能源转型中的重要作用。对于我们普通人来说&#xff0c;从这场大会中可以学到什么呢&#xff1f; 一、储能技术是未来能源发展的关键 随着可再…

李沐《动手学深度学习》线性神经网络 softmax回归

系列文章 李沐《动手学深度学习》预备知识 张量操作及数据处理 李沐《动手学深度学习》预备知识 线性代数及微积分 李沐《动手学深度学习》线性神经网络 线性回归 目录 系列文章一、softmax回归&#xff08;一&#xff09;问题背景&#xff08;二&#xff09;网络架构&#xf…

win11启动docker desktop报错 docker desktop unexpected wsl error

win11启动docker desktop报错 docker desktop unexpected wsl error 解决方式&#xff0c; 第一步&#xff1a;控制面板-启动或关闭windows功能窗口勾选下面两个框框 第二步&#xff1a;执行我下面这些命令&#xff0c;不需要重启电脑

Linux:shell脚本:基础使用(7)《exit和break》

exit是结束脚本&#xff0c;不论在脚本任何地方使用&#xff0c;这个脚本就会立马结束&#xff0c;不会继续执行后面的所有命令 break 是结束循环&#xff0c;break只能在循环中使用&#xff0c;并且只对距离自己最近的循环生效&#xff0c;如果循环嵌套循环那么break在哪个循环…

js菜单隐藏显示

1、树状结构对应的表: 2、生成menulist的SQL语句 select {"id":"MenuID","parent":"ParentID","FirstLvMenu":"FirstLvMenu", "text":"MenuName","url":"MenuUrl",&quo…

Linux基础命令和文件操作理解

1.基础命令 快捷键 ctrl alt t 打开终端 ctrl e 跳转终端输入的末尾 ctrl u 清除一行的命令数据 ctrl a 跳转到终端命令开头 ctrl l 清除整个屏幕&#xff0c;不包括当前行 ctrl r 搜索命令 开启历史模式 寻找最近记录的命令&#xff1a;↑ ↓ 移动光标位置 &#xff1a;← →…

游戏《泰坦陨落2》msvcr120.dll丢失的多种解决方法分享

在Windows 11操作系统环境下&#xff0c;众多玩家在体验《泰坦陨落2》这款备受瞩目的射击游戏时&#xff0c;遭遇了一个令人困扰的技术问题&#xff1a;系统提示缺失msvcr120.dll文件。这一关键的动态链接库文件对于游戏的正常运行至关重要&#xff0c;它的缺失直接导致了《泰坦…

拿出最少数目的魔法豆

说在前面 &#x1f388;不知道大家对于算法的学习是一个怎样的心态呢&#xff1f;为了面试还是因为兴趣&#xff1f;不管是出于什么原因&#xff0c;算法学习需要持续保持。 题目描述 请你从每个袋子中 拿出 一些豆子&#xff08;也可以 不拿出&#xff09;&#xff0c;使得剩…

基于Python+django影片数据爬取与数据分析设计与实现

目录 一、 前言介绍&#xff1a; 二 、功能设计&#xff1a; 三、功能实现&#xff1a; 系统登录实现 管理员实现 用户模块实现 四、库表设计&#xff1a; 五、关键代码&#xff1a; 六、论文参考&#xff1a; 七、其他案例&#xff1a; 八、源码获取&#xff1a; 一…

fastJson和jackson的日期数据处理

目录 1.jackson 2.fastjson 3.总结 1.jackson jackson是spring mvc默认的JSON解析方法&#xff0c;前端的数据序列化处理之后&#xff0c;后端经过反序列化处理可以直接使用实体对象进行接收。后端接口返回实体对象&#xff0c;经过序列化处理后前端可以接收并进行处理。 …

目标检测--02(Two Stage目标检测算法1)

Two Stage目标检测算法 R-CNN R-CNN有哪些创新点&#xff1f; 使用CNN&#xff08;ConvNet&#xff09;对 region proposals 计算 feature vectors。从经验驱动特征&#xff08;SIFT、HOG&#xff09;到数据驱动特征&#xff08;CNN feature map&#xff09;&#xff0c;提高特…

响应式Web开发项目教程(HTML5+CSS3+Bootstrap)第2版 例4-4 label

代码 <!doctype html> <html> <head> <meta charset"utf-8"> <title>label</title> </head><body> 性别: <label for"male">男</label> <input type"radio" name"sex&quo…

多输入多输出 | Matlab实现基于LightGBM多输入多输出预测

多输入多输出 | Matlab实现基于LightGBM多输入多输出预测 目录 多输入多输出 | Matlab实现基于LightGBM多输入多输出预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Matlab实现基于LightGBM多输入多输出预测&#xff08;完整源码和数据&#xff09; 1.data为数据集&a…

java多线程(线程池)

1、创建一个可缓存线程池&#xff0c;如果线程池长度超过处理需要&#xff0c;可灵活回收空闲线程&#xff0c;若无可回收&#xff0c;则新建线程。 public static void main(String[] args) {ExecutorService cachedThreadPool Executors.newCachedThreadPool();for (int i …

npm换源

检查现在的源地址 npm config get registry 使用淘宝镜像 npm config set registry https://registry.npm.taobao.org 使用官方镜像 npm config set registry https://registry.npmjs.org/

安全帽/反光衣检测AI边缘计算智能分析网关V4如何修改IP地址?

智能分析网关V4是TSINGSEE青犀推出的一款AI边缘计算智能硬件&#xff0c;硬件采用BM1684芯片&#xff0c;集成高性能8核ARM A53&#xff0c;主频高达2.3GHz&#xff0c;INT8峰值算力高达17.6Tops&#xff0c;FB32高精度算力达到2.2T&#xff0c;硬件内置了近40种AI算法模型&…
最新文章