redis | 认识非关系型数据库Redis的列表类型及python如何操作redis

news2024/11/15 20:07:26

Redis 非关 kv型

  • 数据类型
  • 列表
    • 常用命令
    • 应用场景
      • 练习
  • pyredis 操作redis
      • ubuntu
      • windows
    • 连接redis
    • 生产者消费者模型

数据类型

数据类型丰富,字符串strings,散列hashes,列表lists,集合sets,有序集合sorted sets等等

列表

在这里插入图片描述

单进程 单线程 尽可能规避掉阻塞的操作

常用命令

  1. LPUSH key value1 value2
    说明:从列表头部压入元素
    返回:list最新的长度

  2. RPUSH key value1 value2
    说明:从列表尾部压入元素
    返回:list最新的长度

  3. 查看列表中元素
    LRANGE key start stop

  4. 获取列表长度
    LLEN key

在这里插入图片描述
在这里插入图片描述

  1. RPOPLPUSH src dst
    说明:从列表srC尾部弹出1个元素,压入到列表dst的头部
    返回:被弹出的元素

  2. LINSERT key after|before value newvalue
    说明:在列表指定元素后/前插入元素
    返回:
    1,如果命令执行成功,返回列表的长度
    2,如果没有找到pivot,返回-1
    3,如果key不存在或为空列表,返回0

  3. 从列表头部弹出1个元素
    LPOP key

  4. 从列表尾部弹出1个元素6
    RPOP key

  5. 列表头部,阻塞弹出,列表为空时阻塞
    BLPOP key timeout

  6. 列表尾部,阻塞弹出,列表为空时阻塞
    BRPOP key timeout

在这里插入图片描述
在这里插入图片描述

关于BLPOP和BRPOP说明
1、如果弹出的列表不存在或者为空,就会阻塞
2、超时时间设置为0,就是永久阻塞,直到有数据可以弹出
3、如果多个客户端阻塞再同一个列表上,使用First In First Service原则,先到先服务

  1. LREM key count value
    说明:删除指定元素
    count:>0:表示从头部开始向表尾搜索,移除与value相等的元素,数量为count
    count<0:表示从尾部开始向表头搜索,移除与value相等的元素,数量为count
    count:=0:移除表中所有与value:相等的值

    返回:被移除元素的数量
    在这里插入图片描述

在这里插入图片描述

  1. LTRIM key start stop
    说明:保留指定范围内的元素
    返回:ok
    场景:
    保存微博评论最后500条 LTRIM weibo:comments 0 499

  2. LSET key index newvalue
    说明:设置Iist指定索引的值

应用场景

1,存储微博评论,做切割,只保留最新的x个
2,生产者消费者模型,做中间层,存放生产者的任务

练习

1、查看所有的键

keys *

2、向列表spider:urls中以RPUSH放入如下几个元素:01 baidu.com、
02 taobao.com,03 sina.com,04 jd.com 05 xxx.com

RPUSH spider:urls 01 baidu.com、
02 taobao.com,03 sina.com,04 jd.com 05 xxx.com

3、查看列表中所有元素

LRANGE spider:urls 0 -1

4、查看列表长度

LLEN spider:urls

5、将列表中01 baidu.com改为01 tmall…com

LSET 0 01 baidu.com 01 tmall…com

6、在列表中04jd.com之后再加1个元素02 taobao.com

LINSERT spider:urls after 04jd.com 02 taobao.com

7、弹出列表中的最后一个元素

RPOP spider:urls

8、删除列表中所有的02 taobao.com

LREM spider:urls 0 02_taobao.com

9、剔除列表中的其他元素,只剩前3条

LTRIM spider:urls 0 2

pyredis 操作redis

ubuntu

除用redis:客户端进行redis操作外,也可以使用Python直接操作redis
检查当前ubuntu是否安装
sudo pip3 freezelgrep -i ‘redis’
安装Python的redis 模块
sudo pip3 install redis

windows

前提是已经安装了redis

  • python安装相关包
    conda install redis
    我的是anconda环境

连接redis

在这里插入图片描述
在这里插入图片描述
返回字节串
[b’k3’,b’l1’,b’k2’,b’uuuname’,b’k1’,b’uuname’]在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

生产者消费者模型

producer.py

import redis
import json

r = redis.Redis(host='',port=,db=,password=)
json_obj = {'task':'send_email','email_body':aaa','from''bbb','to''gxn'}
            
json_str = json.dumps(json_obj)
          
r.lpush('pyl2',json_str)

consumer.py

import redis
import json

r = redis.Redis(host='',port=,db=,password=)

while True:
    task = r.brpop('pyl2',10)
    print(task)
    if task:
        json_obj = json.loads(task[1])
        # 具体任务逻辑
    else:
        print('---no task---')
    break

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

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

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

相关文章

openIM prometheus容器一直重启问题处理

官方文档参考&#xff1a;https://docs.openim.io/zh-Hans/guides/gettingStarted/admin 具体操作&#xff1a; 1、打开 openim-server/config/prometheus.yml 文件&#xff0c;internal_ip改为127.0.0.1&#xff08;内网ip,我的是在本地&#xff09;, 2、第二点说 在 open-i…

我的CSDN-----第128天创作纪念日

机缘 起初的我&#xff0c;是为了在学习代码的过程中通过写博客的方式来巩固自己的知识。后来在遇到不会的问题时可以在csdn上面查找&#xff0c;寻求一点思路&#xff0c;将学到的知识通过博客的方式呈现出来。 收获 每当发布一篇博客后&#xff0c;就会收到很多人的评论加关…

出现Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are requiredProperty报错

目录&#xff1a; bug Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are requiredProperty报错解决方法 bug Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are requiredProperty 报错 在一个springboot demo启动的时候出现以下错误 &#xff0c;…

【前端基础篇】JavaScript之DOM介绍

文章目录 WebAPI背景知识什么是WebAPI什么是APIAPI参考文档 DOM基本概念什么是DOMDOM树查找HTML元素方法概览1. document.getElementById(id)2.document.getElementsByTagName(name)3. document.getElementsByClassName(name)4. document.querySelector(CSS选择器)5. document.…

实习手记(8):增删改查

上周又偷懒了没有按时写博客&#xff08;扣大分啊啊&#xff01;&#xff09;但是好像也没有人看呢~其实最开始也只是想着记录一下实习历程&#xff0c;怕自己之后回过头想关于实习的都想不起来了&#xff0c;个人还是喜欢记录有关自己的学习生活的&#xff0c;就算没啥人看但回…

RabbitMQ 基础总结

一、前言 我们一般的项目过程都是同步通信&#xff0c;及一个服务结束后在执行另一个服务这会让总体时间变得很长&#xff0c;尤其是在高并发的时候用户体验感很不好&#xff0c;且在调用一个服务期间cup内存等都处于空闲状态造成资源浪费 。如果调用其中某一个服务时…

LVS+Keepalived集群(主、备)

1、Keepalived及其工作原理 Keepalived 是一个基于VRRP协议来实现的LVS服务高可用&#xff08;HA&#xff09;方案&#xff0c;可以解决静态路由出现的单点故障问题。 keepalived 高可用之间是通过VRRP进行通信&#xff0c;VRRP是通过竞选的来确定主备&#xff0c;主优先级高…

学习之appium的简单使用

使用之前需要先安装一下依赖 1、安装jdk&#xff1a;暂时为整理笔记以后补充 2、安装nodejs:https://blog.csdn.net/qq_42792477/article/details/141363957?spm1001.2014.3001.5501 3、安装SDk&#xff08;安卓篇&#xff09;&#xff1a;https://blog.csdn.net/qq_42792477…

<数据集>Visdrone数据集<目标检测>

数据集格式&#xff1a;VOCYOLO格式 图片数量&#xff1a;8629张 标注数量(xml文件个数)&#xff1a;8629 标注数量(txt文件个数)&#xff1a;8629 标注类别数&#xff1a;10 标注类别名称&#xff1a;[pedestrian,people,bicycle,car,van,truck,tricycle,awning-tricycle…

HubSpot 自动化营销平台助力出海企业精准获客与转化 | 自动化营销

HubSpot 提供了多个开源 cms 和一体化且全面的解决方案&#xff0c;可帮助出海企业优化内容营销策略 HubSpot 自动化营销加速国际化 随着全球化的推进&#xff0c;越来越多的企业开始寻求拓展国际市场&#xff0c;而在这个过程中&#xff0c;有效的客户关系管理和营销自动化成…

ActiveMQ指南

入门 官网&#xff1a; http://activemq.apache.org/ ActiveMQ 是Apache出品&#xff0c;最流行的&#xff0c;能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现。 JMS JMS即Java消息服务&#xff08;Java Message Service&#xf…

Linux自旋锁和读写锁

在前面的文章中我们已经介绍了有关互斥锁的概念与使用&#xff0c;本篇将开始介绍在 Linux 中的自旋锁和读写锁。这三种锁分别用于在不同的应用场景之中&#xff0c;其中互斥锁最为常用&#xff0c;但是我们需要了解一下其他的锁。 对于自旋锁和读写锁都介绍了其原理以及接口使…

【信创】麒麟KylinOS V10打开root登录桌面权限

原文链接&#xff1a;【信创】麒麟KylinOS V10打开root登录桌面权限 Hello&#xff0c;大家好啊&#xff01;今天给大家带来一篇关于在麒麟KYLINOS V10上如何打开root用户登录桌面的文章。在大多数Linux发行版中&#xff0c;出于安全考虑&#xff0c;root用户默认情况下是禁止直…

KRTS网络模块:TCP服务端、客户端实例

KRTS网络模块:TCP服务端、客户端实例 目录 KRTS网络模块:TCP服务端、客户端实例TCP简介KRST服务端简介核心特性界面设计核心代码 KRTS客户端简介核心特性界面设置核心代码 运行实例 Socket模块基于Packet模块&#xff0c;实时提供更高的协议&#xff0c;如RAW-IP、TCP 和 UDP(参…

【求助帖】用PyTorch搭建MLP网络时遇到奇怪的问题

求助&#xff1a;我在测试自己搭建的通用MLP网络时&#xff0c;发现它与等价的参数写死的MLP网络相比效果奇差无比&#xff0c;不知道是哪里出了问题&#xff0c;请大佬们帮忙看下。 我写的通用MLP网络&#xff1a; class MLP(nn.Module):def __init__(self, feature_num, cl…

3、Unity【基础】Resources资源场景动态加载

文章目录 一、Resources资源动态加载1、Unity中特殊文件夹1、工程路径获取2、Resources资源文件夹3、StreamingAssets流动资源文件夹4、persistentDataPath持久数据文件夹5、Plugins插件文件夹6、Editor编辑器文件夹7、默认资源文件夹StandardAssets 2、Resources同步加载1、Re…

Auto-Editor

文章目录 一、关于 Auto-Editor安装系统兼容性版权 二、切割自动切割的方法看看自动编辑器删掉了什么 三、导出到编辑器命名时间线按 Clip 分割 四、手工编辑五、更多的选择 一、关于 Auto-Editor github : https://github.com/WyattBlue/auto-editor (2.8k star – 2408)主页…

ubuntu 20.04系统安装pytorch

1.1 安装gcc 安装cuda之前&#xff0c;首先应该安装gcc&#xff0c;安装cuda需要用到gcc&#xff0c;否则报错。可以先使用下方指令在终端查看是否已经安装gcc。 gcc --version 如果终端打印如下则说明已经安装。 如果显示“找不到命令 “gcc”......”使用下方指令安装 su…

阅读笔记5:董超底层视觉之美|时空的交错与融合——论视频超分辨率

原文链接&#xff1a;https://mp.weixin.qq.com/s/pmJ56Y0-dbIlYbHbJyrfAA 1. 多帧超分和时空超分 视频超分的本质就是多帧超分&#xff0c;多帧超分的历史远早于视频超分。 在早期&#xff0c;Super Resolution专指多帧超分&#xff0c;因为只有多帧超分才能补充进入真实的信…

Golang | Leetcode Golang题解之第368题最大整除子集

题目&#xff1a; 题解&#xff1a; func largestDivisibleSubset(nums []int) (res []int) {sort.Ints(nums)// 第 1 步&#xff1a;动态规划找出最大子集的个数、最大子集中的最大整数n : len(nums)dp : make([]int, n)for i : range dp {dp[i] 1}maxSize, maxVal : 1, 1fo…