百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python使用redis的消息队列(python中redis)

off999 2024-11-04 13:16 35 浏览 0 评论

Redis 服务

  1、安装
  yum install redis
  2、 python安装支持模块
  /opt/python2.7.13/bin/pip install redis
  3、 和redis的简单直接交互
  In [1]: import redis
  In [2]: rc = redis.Redis(host='192.168.8.237',port=6379,decode_responses=True)
  In [5]: rc.set('imoocc','jeson')
  Out[5]: True
  In [7]: rc.get('imoocc')
  Out[7]: u'jeson'

Redis简单操作

对于和Redis的交互, Redis的类中提供了连接池的方式,我们可以通过连接池管理并操作Redis。

  1、连接池建立,利用连接池连接
  In [8]: connpool = redis.ConnectionPool(host='192.168.8.237',port=6379,decode_responses=True)
  In [9]: rc = redis.Redis(connection_pool=connpool)
  In [10]: rc.set('imooccp','1234566')
  Out[10]: True
  In [11]: rc.get('imooccp')
  Out[11]: u'1234566'
  2、redis中DB ,指定数据存取的DB
  redis.conf中设置了db的数量,那么redis的数据库名也为0 到15,如下:
  databases 16
  指定使用那个数据库名,我们通过如下的方式,就可以了:
  In [29]: connpool = redis.ConnectionPool(host='192.168.8.237',port=6379,decode_responses=True,db=3)
  In [30]: rc.set('test2','lllll')
  Out[30]: True
  这样就将数据库写入到db3了,如何验证呢?我们从服务端来认证最直接,如下:
  用redis-cli(redis自带的工具)登录服务端,查看写入的key。
  127.0.0.1:6379> SELECT 3
  OK
  127.0.0.1:6379[3]> KEYS * //查看db 3这个库下所有的key
  1) "imooccc"

那么 接下来介绍redis详细项目使用的内容,大家不要觉得介绍的内容扩散太大。

最近在作一个任务系统,任务写入是不定时的,我们需要用一个程序去定期消费这些任务,必须是有先后顺序的,而且是前一个任务确认执行完后,才会去执行下一个。

怎么办呢?用队列啊,对吧!用什么队列,怎么用?

介绍下为什么要用redis来作消息处理:

简单说,redis支持两种消费模式,一种发布-订阅模式,及一个消息会被多个消费者处理(简单说类似是一个广播消息,所有人都会接收)。很明显我得系统中不需要这么用,系统里边就需要队列模式,及先到的任务优先处理。那么对队列用什么类型得数据库结构来作呢?

先得聊聊list

list 这个数据类型,在python里是一个列表,在redis里就是一个有序队列(或者说数据链表)了。

类型图示如下:


大家看了这个结构就可以清楚了,我们可以利用list的数据接口模式,设计从左端和右端都可以对list进元素的同向处理(满足队列的特性先到先出)。

  1、从左端插入元素
  In [10]: rc.lpush('tasklist',1,2,3)
  Out[10]: 3L
  打印输出内容,如下:
  In [17]: print(rc.lrange('tasklist',0,2))
  [u'3', u'2', u'1']
  类似的从左测插入的方法还有lpushx(name,value),区别只有当name存在才将value插入到最左边。
  2、从右边插入元素
  In [21]: rc.rpush('tasklist','5')
  Out[21]: 5L
  In [22]: print(rc.lrange('tasklist',0,4))
  [u'4', u'3', u'2', u'1', u'5']
  3、从左边取出元素怎么取呢?
  In [23]: rc.lpop("tasklist")
  Out[23]: u'4'
  In [24]: rc.lpop("tasklist")
  Out[24]: u'3'
  In [25]: print(rc.lrange('tasklist',0,4))
  [u'2', u'1', u'5']
  我们会看到从左侧已经取出了两个元素了。剩下来[u'2', u'1', u'5']
  4、从右侧呢?
  当然就是rc.rpop()了
  python对于redis的基础使用和Redis作为队列的简单使用就介绍这些,
  python的工程里边如何更好封装redis库的连接和方法,
  及python很多的知识内容,大家可以关注我,我将提供更多的内容!

相关推荐

hotmail邮箱还能用吗(hotmail邮箱登录有手机客户端的吗)

这个是可以重新申请的呢除了谷歌国内受限,其他基本都可以正常使用。看个人使用习惯可自主申请相应邮箱:微软outlook、hotmail邮箱;网易邮箱、网易126邮箱;新浪邮箱、阿里邮箱;QQ邮箱、搜狐...

怎么建立局域网(怎么建立局域网内其他电脑文件夹的快捷方式)
  • 怎么建立局域网(怎么建立局域网内其他电脑文件夹的快捷方式)
  • 怎么建立局域网(怎么建立局域网内其他电脑文件夹的快捷方式)
  • 怎么建立局域网(怎么建立局域网内其他电脑文件夹的快捷方式)
  • 怎么建立局域网(怎么建立局域网内其他电脑文件夹的快捷方式)
diskdigger官网入口(diskinfo官网)

打开LaunchCenterPro,创建一个叫Omnifocus的操作组,然后再往这个操作组添加新的操作。如果你要在Omnifocus创建新收件箱项,添加URL到LaunchCenter...

最新英特尔处理器排名(最新英特尔处理器排名第几)

一、英特尔酷睿i7670。这款英特尔CPU采用的是超频新芯,最大程度的提升处理器的超频能力。二、英特尔酷睿i74790kCPU:这款CPU采用22纳米制程工艺的框架,它的默认频率是4.0到4.4Ghz...

电脑怎样激活win10系统(电脑怎么激活window10)
  • 电脑怎样激活win10系统(电脑怎么激活window10)
  • 电脑怎样激活win10系统(电脑怎么激活window10)
  • 电脑怎样激活win10系统(电脑怎么激活window10)
  • 电脑怎样激活win10系统(电脑怎么激活window10)
nvidia旧版本驱动下载(nvidia新版本驱动)
nvidia旧版本驱动下载(nvidia新版本驱动)

没法装,n卡本身不具备装旧版驱动的功能一、首先在本机电脑内鼠标左键双击打开“驱动人生”(若电脑上无此软件,可以在各大软件市场内下载安装)。二、打开驱动人生软件后,点击“立即体检”进行驱动扫描。三、驱动扫描完成后,点击显卡右边的“箭头”打开驱...

2025-12-18 20:51 off999

怎么解开别人的wifi密码(如何解开别人的wifi密码)

别人的无线网络密码是很不容易破解的,如果人家是愿意分享的,可以在手机上下载"Wifi万能钥匙"注册登陆成功后连接其无线wifi1、以现有的技术手段,是没有办法破解WPA的加密方式(现在...

电脑突然关机(电脑突然关机像断电了一样 再也打不开)
电脑突然关机(电脑突然关机像断电了一样 再也打不开)

如果是插电源的电脑开着突然就关机了,可能是线路接触不良或者是没电了,导致的开着就关机了,如果是你的电脑是充电的那一种可能是你的电池的电量用完了或者是电池的线路接触不良导致的开着突然就关机了,你可以排查一下线路。1、如果你使用的是笔记本电脑,...

2025-12-18 19:51 off999

win7重装系统一直反复重启(win7重装系统无限重启)

WIN7的系统装重复了,可以将原安装的系统删除,方法如下:1、如果以前的windows是安装在C盘上的话,点击桌面上的计算机,选中C盘,鼠标右键选择属性;2、点磁盘清理;3、点清理系统文件,点确定;4...

电脑如何格式化sd卡(电脑格式化sd卡,提示写有保护)

要在电脑上格式化SD卡,可以按照以下步骤:1.将SD卡插入计算机的SD卡读卡器中。2.打开“我的电脑”或“此电脑”,找到SD卡在计算机上的驱动器号(比如E盘)。3.右键单击SD卡驱动器,选择“格...

系统检测不到机械硬盘(系统检测不到机械硬盘怎么办)

第一,我们需要确认一下机械硬盘是否连接正常。可以检查一下硬盘的电源线和数据线是否插紧,是否松动或者断开。如果发现有松动或者断开的情况,可以重新插上并确保插紧。如果硬盘连接正常,但电脑仍然无法读取,那么...

路由器管理平台登录(路由器管理平台登录网址)

路由器的用户登录入口地址是:tplogin.cn电信运营商定制款登录地址是:192.168.2.1或者192.168.8.12、华为(容易)路由器华为路由器跟荣耀路由器只有IP地址,没有域名,它是...

directx修复(DirectX修复工具官网下载)

使用DirectX修复工具很简单。首先需要下载并安装工具,然后打开工具并按照界面提示进行操作即可。工具的作用是自动检测系统中可能存在的DirectX问题,并尝试修复它们,从而保证计算机游戏等应用程序的...

网易邮箱app官方下载安装(网易邮箱163)
网易邮箱app官方下载安装(网易邮箱163)

有些东西调用外部下载软件(如迅雷)是无法下载的,有时下载后不能正常打开,请尝试:在所要下载的文件上点击右键,选择“目标另存为”,也许就能成功下载。下载从网易163邮箱发来的云附件的步骤如下:1.成功登录网易邮箱后,我们点击页面左上角的“收件...

2025-12-18 16:51 off999

产品密钥是什么意思(产品密钥有什么用处)

产品密钥是产品授权的证明,有了它才能使用这个产品。软件商在生产自己产品时,为每个产品输入一个序列号(注册号/密钥),如“KH2J9-PC326-T44D4-39H6V-TVPBY”,用户要通过这个序列...

取消回复欢迎 发表评论: