Redis相关技术内容

1. Redis整体的技术全景

  • 应用场景:数据结构的应用、缓存应用、集群应用

  • 底层原理:线程模型、主从复制、负载均衡

    ​ 数据结构、哨兵机制、数据分片

    ​ AOF、 RDB

2. 并发承载

  • redis(官方 10w/s)
  • 数据库->mysql 并发范围:写:600/s 读 2000/s

3. Redis的基本数据类型

基本数据类型:string、hash、list、set、zset。

3.1 string类型

  • setnx 不存在才set

    set a 1 nx

  • setxx 存在才set

    set b 2 xx

  • mset 批量set

    mset a 1 b 2 c 3

  • mget 批量获取

    mget a b c d

  • incr incr-key 自增值

    set incr-key 1

    incr incr-key

  • decr incr-key 自减

    decr incr-key

  • getset hello hello 获取到旧的值

    set hello 1

    getset hello newvalue 此时返回的是1,但是hello已经被设置成newvalue

  • setrange hello 5 x 将hello 第5的位置设置成x

  • getrange hello 1 4 获取范围

3.2 hash类型

可以用于存储关系型数据库的二维表结构的数据。

  • hset user:1 name li 在user:1的数据上存储了name:li的值

  • hset user:1 age 24

  • hmset user:2 name zhang age 18 批量设置

  • hsetnx user:1 name li

  • hget user:1 name 拿到user:1数据上的name对应的值

  • hmget user:1 name age

  • hlen user:1 取出长度数据

  • hvals user:1 取出所有的key的值

  • hkeys user:1 取出所哟key的名称

  • hgetall user:1 取出所有key value

  • hincrby user:1 id 2 自增内部字段的值

3.3 list类型

存储最多的元素个数:2的32次方-1个(4294967296)

有序的元素。

  • rpush demolist a 向右边插入一个值
  • lpush demolist b 向左边插入一个值
  • lrange demolist 0 -1 取出list的所有值列表
  • lpop demolist 2 弹出元素右边两个(不传入参数则默认为一个)元素
  • lrem demolist 2 y 从作向右删除2个y
  • ltrim demolist 0 1 保留0-1位置的值
  • lset demolist 1 xx 将1位置值改成xx
  • lindex demolist 1 取出1位置的值
  • llen demolist list的长度

应用场景可以是:文章列表,做分页有序,支持范围的业务。

3.4 set类型

没有重复的数据集合

  • sadd demoset a b c d e f d d 添加后会进行去重
  • smembers demoset 查看集合所有值
  • srem demoset c d 删除指定值
  • smemebers demoset a 查询元素是否存在
  • scard demoset 查存在多少个元素
  • srandmember demoset 随机返回一个元素
  • spop demoset 弹出一个元素
  • del demoset 删除key
  • sinter set1 set2 求并集
  • sunion set1 set2 求交集
  • sdiff set1 set2 求差集
  • sinterstore interset set1 set2 将交集结果存在interset(set)中

应用场景:打标签,生成随机数这样的场景。

3.5 zset类型

结构是key :二维的score、member表格存储的值

  • zadd zset 90 lisi

  • zadd zset 95 wangwu

  • zadd zet 100 zhangsan

  • zcard zset 查看值多少条记录

  • zscore zset lisi 查看lisi的分数

  • zrank zset lisi 查看lisi的排名

  • zrevrank zset lisi 反转排序取出lisi的排名

  • zincrby zset 6 lisi 将lisi的分数增加6分

  • zrange zset 0 1 withscores 获取到按照升序、排名前二的姓名和成绩

  • zrevrange zset 0 1 withscores 反转获取到降序、排名前二的姓名和成绩

  • zrangebyscore zset 96 100 分数范围查询

应用场景:求平均成绩

  • zinterstore zsetavg 2 set1 set2 weights 0.5 0.5
  • zrange zsetavg 0 -1 withscores

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

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

相关文章

深入理解JVM

文章目录 1. JVM内存区域划分2. JVM中类加载过程类加载(1)类加载的基本流程(2)双亲委派模型 《深入理解java虚拟机》 在这本书前,面试官对于JVM也不是很了解。 这本书主要还是写个一下开发 JVM 的人。 1. JVM内存区域…

如何选情绪龙头

一、情绪龙头的特性及选股指标 情绪龙头股在市场中的表现往往具有独特的特性,这些特性不仅反映了市场的情绪波动,也为投资者提供了重要的选股依据。以下是情绪龙头股的十大特性及其对应的选股指标: 1. 高波动性 情绪龙头股通常具有极高的股…

启动软件是用例吗

沙亚雄 2020-8-13 14:06 潘老师,你好,最近读了您的软件方法,结合自己的项目发现始终有一个疑问?那就是启动软件算不算一个用例,因为软件在启动的时候一般都要实例化一些对象,读一些配置文件等等。那启动软…

Ubuntu22.04中使用CMake配置运行boost库示例程序

Ubuntu22.04中使用CMake配置运行boost库示例程序 boost是一个比较强大的C准标准库,里面有很多值得学习的东西,比较asio网络库可以用来编写C TCP客户端或者TCP服务端接收程序。本文主要讲解如何在Ubuntu22.04中使用Cmake配置boost库,以及运行…

弄巧成拙的 PFC(Priority-based Flow Control)

先说几句车轱辘话,TCP 性能低,所以 RDMA,以太网丢包,所以 PFC,网卡不能太复杂,所以 GBN… HPC,AI 对吞吐,时延要求非常高,同时需要更多计算资源,而 TCP 处理…

指标+AI+BI:构建数据分析新范式丨2024袋鼠云秋季发布会回顾

10月30日,袋鼠云成功举办了以“AI驱动,数智未来”为主题的2024年秋季发布会。大会深度探讨了如何凭借 AI 实现新的飞跃,重塑企业的经营管理方式,加速数智化进程。 作为大会的重要环节之一,袋鼠云数栈产品经理潮汐带来了…

Windows配置NTP时间同步

Windows下实现NTP时间同步 1、Windows时间服务(W32Time)2、Windows 时间同步的工作原理3、配置和管理 Windows 时间同步3.1 命令行工具:w32tm3.2 控制面板中的设置 4. 高级设置(Windows Server 环境)5.调整时间同步的间隔5.1 通过组策略调整时…

系统安全第七次作业题目及答案

一、 1.RBAC0 RBAC1 RBAC2 RBAC3 2.属性 身份标识 3.接入访问控制 资源访问控制 网络端口和节点的访问控制 二、 1.B 2.A 3.ABE 4.BCD 5.ABC 三、 1. 答:基于属性的访问控制(ABAC)是通过对实体属性添加约束策略的方式实现主、客体之…

Golang进阶

1.面向对象 1.1.golang语言面向对象编程说明 Golang 也支持面向对象编程(OOP),但是和传统的面向对象编程有区别,并不是纯粹的面向对象语言。所以我们说 Golang 支持面向对象编程特性是比较准确的。Golang 没有类(class),Go 语言的结构体(st…

Node(节点)、Menu(菜单) 和 Tab(标签页)之间的关系

在系统开发中,尤其是在涉及到前端界面设计和后台管理系统时,我们经常会看到 Node(节点)、Menu(菜单) 和 Tab(标签页) 这几个概念。这些概念有不同的用途和功能,理解它们之…

C# WPF 打印机

C# WPF 打印机 打印机接口打印文本打印图片打印机属性对话框设置默认打印机搜索打印机 打印机接口 PrintServerPrintQueuePrintDocument 打印文本 /// <summary> /// 打印文本 /// </summary> /// <param name"text"></param> /// <pa…

Python数据分析案例64——杭帮菜美食探索数据分析可视化

案例背景 杭州是真没啥美食呀.....但是 总是还是有好吃的店家&#xff0c;于是就发挥专业长处&#xff0c;进行一下分析&#xff0c;看看杭帮菜的一些特点。。例如看看品种分布啊&#xff0c;类型分布啊&#xff0c;行政区的分布啊&#xff0c;店铺评分的一些分布啊&#xff0…

基于SSD模型的路面坑洼检测系统,支持图像、视频和摄像实时检测【pytorch框架、python源码】

更多目标检测和图像分类识别项目可看我主页其他文章 功能演示&#xff1a; 基于SSD模型的路面坑洼检测系统&#xff0c;支持图像、视频和摄像实时检测【pytorch框架、python源码】_哔哩哔哩_bilibili &#xff08;一&#xff09;简介 基于SSD模型的路面坑洼检测系统是在 Py…

《Python编程实训快速上手》第四天--字符串操作

一、处理字符串 1、单引号和双引号 Python中单双引号均可以表示字符串&#xff0c;区别在于&#xff1a; 1、双引号中可以使用到单引号 2、单引号字符串中如果要使用单引号&#xff0c;要使用到转义字符 \ \ \t \n \\ 原始字符串 在开始的引号前加r&#xf…

泷羽sec学习打卡-Windows基础命令

声明 学习视频来自B站UP主 泷羽sec,如涉及侵权马上删除文章 笔记的只是方便各位师傅学习知识,以下网站只涉及学习内容,其他的都与本人无关,切莫逾越法律红线,否则后果自负 关于windows的那些事儿-Base 一、Windows-BaseWindows有哪些版本呢&#xff0c;有什么区别呢&#xff1f…

Node.js——fs模块-文件夹操作

1、借助Node.js的能力&#xff0c;我们可以对文件夹进行创建、读取、删除等操作 2、方法 方法 说明 mkdir/mkdirSync 创建文件夹 readdir/readdirSync 读取文件夹 rmdir/rmdirSync 删除文件夹 3、语法 其余的方法语法类似 本文的分享到此结束&#xff0c;欢迎大家评论区…

Java与HTML:构建静态网页

在Web开发领域&#xff0c;HTML是构建网页的基础标记语言&#xff0c;而Java作为一种强大的编程语言&#xff0c;也能够在创建HTML内容方面发挥重要作用。今天&#xff0c;我们就来探讨一下如何使用Java来制作一个不那么简单的静态网页。 一、项目准备 首先&#xff0c;我们需…

Java 中的 Consumer:让操作与输出更简洁灵活

文章目录 1. Consumer 基础&#xff1a;单一操作的便捷实现2. forEach 与 Consumer&#xff1a;循环中的简化操作3. 链式 Consumer&#xff1a;andThen 实现多个操作4. 配合 Map 使用&#xff1a;多用途数据处理5. 定义通用 Consumer&#xff1a;增强代码复用6. Consumer 配合 …

VMware Fusion和centos 8的安装

资源 本文用到的文件&#xff1a;centos8镜像 , VMware 软件包 , Termius 文件链接: https://pan.baidu.com/s/1kOES_ZJ8NGN-BnJl6NC7Sg?pwd63ct 安装虚拟机 先 安装 vmware &#xff0c;然后打开&#xff0c;将下载的 iso 镜像拖入 拖入镜像文件iso Continue, 然后随便选…

【嵌入式开发——ARM】1ARM架构

嵌入式领域&#xff0c;使用ARM架构的芯片公司可不占少数吧&#xff0c;intel的x86架构主要占据PC、服务器市场&#xff0c;ARM架构主要占据移动市场。x86架构和ARM架构不同的主要原因&#xff0c;是背后使用的计算机指令集不同。计算机有自己的语言系统&#xff08;汇编&#…