Redis: Redis介绍

文章目录

  • 一、redis介绍
  • 二、通用的命令
  • 三、数据结构
    • 1、字符串类型(String)
      • (1)介绍
      • (2)常用命令
      • (3)数据结构
    • 2、列表(List)
      • (1)介绍
      • (2)常用命令
      • (3)数据结构
    • 3、集合(Set)
      • (1)介绍
      • (2)常用命令
      • (3)数据结构
    • 4、哈希(Hash)
    • 5、有序集合(Zset)

一、redis介绍

redis是一个基于内存的键值型NoSQL数据库,具有如下特征:

  • 键值型,value可以执行多种不同的数据结构string、list、set、hash和zset等功能丰富。
  • 单线程操作,每个命令都具有原子性
    • 所谓的原子操作值的是不会被线程调度机制打断的操作,这种操作会一直运行到结束,中间不会进行线程切换。对于原子操作的理解可以分为如下两种:
      • 在单线程中,能够在单条指令中完成的操作就是原子操作。中断只发生于指令之间。
      • 在多线程中,不会被其他线程打断的操作就是原子操作。
  • 高性能,低延迟、速度快(基于内存、IO多路复用)
  • 高可用,具有主从、集群和哨兵模式
  • 支持java、c和python等多种语言

二、通用的命令

Redis命令官方地址:https://redis.io/commands,有如下通用的命令:

  • help [command]
    查看一个命令的具体用法
    在这里插入图片描述
  • keys *
    查看库中的所有key或符合模板的所有key。
    在这里插入图片描述
  • DEL [command]:
    删除一个指定的key
  • exists key
    判断某个key是否存在。
  • move key db 当前库就没有了,被移除了。
  • expire key 秒钟
    为给定的key设置过期时间。
    在这里插入图片描述
  • ttl key
    看还当前key还有有多少秒过期,-1表示永不过期,-2表示已过期。
    在这里插入图片描述
  • type key 查看你的key是什么类型。
  • select
    切换数据库
  • dbsize
    查看当前数据库key的数量
  • flushdb
    清空当前库
  • flushall
    清空全部库
  • unlink key
    根据key选择非阻塞删除,仅将keys从keyspace元数据中删除,真正的删除会在后续异步操作

三、数据结构

常用的五大数据结构。

1、字符串类型(String)

(1)介绍

该类型是redis中最简单的存储形式,其value是字符串,可分为三种:

  • String:普通的字符串类型
  • int:整型类型,可以进行加减操作
  • float: 浮点型,可以进行加减操作

(2)常用命令

  • set
    添加或者修键值对
    在这里插入图片描述
  • mset key value [key value …]
    批量添加键值对
  • get key
    根据key获取value
  • mget key [key …]
    根据多个key获取多个value
    在这里插入图片描述
  • incr
    让一个整型的key自增1,相当于java中的i++
  • incrby
    让一个整数按照指定的步长增长
  • incrbyfloat
    让一个浮点类型的数字按照指定步长增长
  • setnx
    设置键值对,如果该key存在则不执行。
    在这里插入图片描述
  • msetnx
    当key都不存在时,可以同时设置多个键值对,且该操作具有原子性,如果有一个设置失败,则都失败。
    在这里插入图片描述
  • setex
    添加一个String类型的键值对,并且指定有效期
  • getrange
    字符串截取,类似于java中的subString操作
    在这里插入图片描述
  • setrange
    在这里插入图片描述
  • getset
    在这里插入图片描述

(3)数据结构

String类型的数据结构为动态字符串,内不能的存储结构类型与java中的ArrayList采用预分配的方式来减少内存的频繁扩容。

2、列表(List)

(1)介绍

是一个字符串列表单键多值,它的底层是一个创建链表,对两端的操作性能很高,通过索引操作中间节点性能较差。

(2)常用命令

  • lpush/rpush
    从列表的左边/右边插入一个或多个值
  • rpoplplush key1 key2
    从key1列表右边获取一个值,并将该值从key1列表中移除,插入到key2列表左边。
  • lrange key start stop
    按照索引下标获取元素(从左到右)
  • lindex key index
    按照索引下标获取元素
  • lpop/rpop key
    从左边/右边获取一个值,并在队列中移除该值,没有值则返回nil
  • linsert key before value newvalue
    在value后面插入新值newvalue
  • lrem key n
    从左边删除n个
  • lset key index value
    将列表key下标为index的值替换为value
  • llen key
    获取列表的长度
  • BLPOP和BRPOP
    该命令会按照key的顺序查找list,直到找到第一个非空的list获取并移除该list最左边或最右边的第一个元素。此外还可以在指定的时间内获取列表中的元素,如果在指定的时间内没有元素则阻塞等待。
    在这里插入图片描述
    SpringBoot中代码应用:
 public List<String> pop(List<String> keys, int timeout) {return stringRedisTemplate.execute(connection -> {Assert.isTrue(connection instanceof DefaultStringRedisConnection, "Connection is not DefaultStringRedisConnection!");DefaultStringRedisConnection defConnection = (DefaultStringRedisConnection) connection;List<String> value = defConnection.bLPop(timeout, keys);log.info("bLPop blocked left pop, queues: {}, value: {}", keys, value);return value;}, true);}

(3)数据结构

List的数据结构为快速链表,当列表元素较少的情况下使用的是连续的存储空间进行存储被称为zipList(压缩链表),当元素较多的时候会转换成quickList = 链表+zipList
在这里插入图片描述

3、集合(Set)

(1)介绍

该类型与java中的hashSet结构类型,底层存储结构也是hash表,与HashSet有相同的特征:

  • 无序
  • 元素不可重复
  • 查找快
  • 支持交集、并集和差集等操作

(2)常用命令

  • SADD key member …
    向key中添加一个或多个元素
  • SREM key member …
    移除key中指定的若干个元素
  • SCARD key
    返回key中的元素个数
  • SISMBMBER key member
    判断一个是否咋key中存在
  • SMEMBERS key
    获取key的所有元素
  • SINTER key1 key2 …
    求交集
  • SDIFF key1 key2 …
    求差集
  • SNUION key1 key2 …
    求并集

(3)数据结构

底层使用的是hash表结构

4、哈希(Hash)

5、有序集合(Zset)

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据结构】链表的分类和双向链表

本篇是基于上篇单链表所作&#xff0c;推荐与上篇配合阅读&#xff0c;效果更加 http://t.csdnimg.cn/UhXEj 1.链表的分类 链表的结构非常多样&#xff0c;以下情况组合起来就有8种&#xff08;2 x 2 x 2&#xff09;链表结构&#xff1a; 我们一般叫这个头为哨兵位 我们上回…

三星S24未破智能手机藩篱,AI Phone继续期待黑马

匆忙离开深圳机场的时候&#xff0c;《智物》遇到几位熟悉的老朋友。习惯了在中国市场边缘生存的&#xff0c;全球第一代智能手机企业三星公司&#xff0c;刚刚在此地录制完了新旗舰手机三星S24系列的发布会视频。 贵为全球第一大智能手机品牌的三星发布会居然不是直播。韩式套…

【嵌入式学习】C++QT-Day2-C++基础

笔记 见我的博客&#xff1a;https://lingjun.life/wiki/EmbeddedNote/19Cpp 作业 自己封装一个矩形类(Rect)&#xff0c;拥有私有属性:宽度(width)、高度(height)&#xff0c; 定义公有成员函数: 初始化函数:void init(int w, int h) 更改宽度的函数:set_w(int w) 更改高度…

PowerBI商业智能分析引入,带你了解什么是商务智能

一、商务智能工具 什么是Power BI &#xff1f;Power Bl是微软开发的一个软件&#xff0c;它是从获取数据、数据清洗、数据图表搭建、数据分析、共享发布为一体的软件&#xff0c;无论你的数据是简单的Excel电子表格&#xff0c;还是复杂庞大的数据库&#xff0c;Power Bl都可…

Linux-共享内存

文章目录 前言一、system V共享内存申请共享内存挂载共享内存删除共享内存挂载删除共享内存 二、示例代码三.运行效果 前言 在这之前我们已经学习了两种进程间通信方式&#xff1a;匿名管道和命名管道。 从我们之前的学习已经知道&#xff0c;想让多个进程间进行通信就需要让他…

sql管理工具archery简介

在平时的工作过程中&#xff0c;我们肯定会遇到使用sql平台的场景&#xff0c;业内也有很多工具&#xff0c;类似阿里云的dms&#xff0c;但是这个是和云厂商绑定的&#xff0c;我们可能一般没有用到阿里云组件就比较困难了&#xff0c;那还有什么选项了&#xff0c;经过调研&a…

创建第一个 Spring 项目(IDEA社区版)

文章目录 创建 Spring 项目创建一个普通的 Maven 项目添加 Spring 依赖IDEA更换国内源 运行第一个 Spring 项目新建启动类存储 Bean 对象将Bean注册到Spring 获取并使用 Bean 对象 创建 Spring 项目 创建一个普通的 Maven 项目 首先创建一个普通的 Maven 项目 添加 Spring 依…

Windows11 Copilot助手开启教程(免费GPT-4)

Windows11上开启Copilot助手教程踩坑指南 Copilot介绍Copilot开启步骤1、更新系统2、更改语言和区域3、下载 ViVeTool 工具4、开启Copilot 使用 Copilot介绍 Windows Copilot 是 Windows 11 中的一个新功能&#xff0c;它可以让你与一个智能助理进行对话&#xff0c;获取信息&…

05-Seata下SQL使用限制

不支持 SQL 嵌套不支持多表复杂 SQL(自1.6.0版本&#xff0c;MySQL支持UPDATE JOIN语句&#xff0c;详情请看不支持存储过程、触发器部分数据库不支持批量更新&#xff0c;在使用 MySQL、Mariadb、PostgreSQL9.6作为数据库时支持批量&#xff0c;批量更新方式如下以 Java 为例 …

k8s架构、工作流程、集群组件详解

目录 k8s概述 特性 作用&#xff08;为什么使用&#xff09; k8s架构 k8s工作流程 k8s集群架构与组件 核心组件详解 Master节点 Kube-apiserver Kube-controller-manager Kube-scheduler 存储中心 etcd Node Kubelet Kube-Proxy 网络通信模型 容器引擎 k8s核…

Java-NIO篇章(5)——Reactor反应器模式

前面已经讲过了Java-NIO中的三大核心组件Selector、Channel、Buffer&#xff0c;现在组件我们回了&#xff0c;但是如何实现一个超级高并发的socket网络通信程序呢&#xff1f;假设&#xff0c;我们只有一台内存为32G的Intel-i710八核的机器&#xff0c;如何实现同时2万个客户端…

http接口测试—自动化测试框架设计

一、测试需求描述 对服务后台一系列的http接口功能测试。 输入&#xff1a;根据接口描述构造不同的参数输入值&#xff08;Json格式&#xff09; 输出&#xff1a;字符串&#xff08;传入的方式传入的字符串&#xff09; http://localhost:8090/lctest/TestServer 二、程序设计…

C4.5决策树的基本建模流程

C4.5决策树的基本建模流程 作为ID3算法的升级版&#xff0c;C4.5在三个方面对ID3进行了优化&#xff1a; &#xff08;1&#xff09;它引入了信息值&#xff08;information value&#xff09;的概念来修正信息熵的计算结果&#xff0c;以抑制ID3更偏向于选择具有更多分类水平…

SpringCloud Aliba-Seata【下】-从入门到学废【8】

目录 1.数据库创建 1.seata_account库下建表 2.seata_order库下建表 3.seata_storage库下建表 4.在每个库下创建回滚日志 2.创建订单模块 2.1建工程 2.2加pom 2.3改yml 2.4file.conf 2.5registry.conf 2.6domain 2.7Dao 2.8Service 2.9controller 2.10confi…

BGP路由反射-数据中心IDC项目经验

一、背景描述 R1,R2,R3在AS200区域内&#xff0c;R1和R2,R1和R3建立OSPF&#xff0c;宣告接口互联. AS200区域内&#xff0c;R1和R2建立IBGP, R1和R3建立IBGP R2和R4建立EBGP, R3和R5建立EBGP。 网络拓扑&#xff1a; 二、故障现象 R1和R2可以收到来自AS100区域R4的E…

pytorch实战-6手写数字加法机-迁移学习

1 概述 迁移学习概念&#xff1a;将已经训练好的识别某些信息的网络拿去经过训练识别另外不同类别的信息 优越性&#xff1a;提高了训练模型利用率&#xff0c;解决了数据缺失的问题&#xff08;对于新的预测场景&#xff0c;不需要大量的数据&#xff0c;只需要少量数据即可…

Unity通用渲染管线升级URP、HDRP

Unity通用渲染管线升级URP、HDRP 一、Build-in Pipline升级到 URP 一、Build-in Pipline升级到 URP 安装URP包 升级所有材质&#xff08;升级完成后材质会变成紫红色&#xff0c;Shader丢失&#xff0c;此为正常现象&#xff09; 创建 UniversalRenderPipelineAsset 配置文…

Nacos 在云原生架构下的演进

作者&#xff1a;之卫 背景 Nacos 提供的最核心能力是动态服务发现与动态配置管理能力&#xff0c;在云原生环境下&#xff0c;借助云产品&#xff0c;如 EDAS&#xff08;企业级分布式应用服务&#xff09;平台中&#xff0c;我们可以很轻松地使用 K8s 来托管 Nacos 体系的微…

蓝桥杯(Python)每日练Day5

题目 OJ1229 题目分析 题目完全符合栈的特征&#xff0c;后进先出。如果能够熟练使用列表的9种方法那么这道题很容易解出。 题解 a[]#存衣服 nint(input()) for i in range(n):llist(input().split())#判断每一步的操作if len(l[0])2:a.append(l[1])else:while a.pop()!l…

大数据平台红蓝对抗 - 磨利刃,淬精兵!

背景 目前大促备战常见备战工作&#xff1a;专项压测&#xff08;全链路压测、内部压测&#xff09;、灾备演练、降级演练、限流、巡检&#xff08;监控、应用健康度&#xff09;、混沌演练&#xff08;红蓝对抗&#xff09;&#xff0c;如下图所示。随着平台业务越来越复杂&a…