通过memcached实现领号排队功能及python队列实例

简介:

前言:

前段时间写的那个域用户平台,要做大量的新功能运维测试,据说要抄IT组,让那帮人到搞,跑一下 ! 尼玛,这可吓坏了我了。 因为平台要和windows做大量的交互,那边powershell又很不给力,改成多线程版本后,出现莫名的问题,很让人闹心。现在的状态是,client给server端可以同时推送两片信息,要是多的话,powershell实在处理不了,我只能放到queue队列里面了。


现在很多的堵塞都是在windows那边,我这边因为用的是tornado,对于用户访问是无压力的,但是windows那边不能同时运行多了,不然会提示bug。。

ad的信息我暂时还没有批量的同步过来,所以只能单点搞了 ~

   一直在想咋才能不出丑。所以做了好多的限制,比如短信接口的token机制,用户更新接口的次数的限制。 现在唯一的节点就是和win那边的交互。别等到了周一的时候,一帮人把 获取手机号码、修改密码、更新用户信息的接口给点爆了。

   突然想到12306那个渣渣,可以用排队呀。。。 这样的话,最少能看起来很高端的样子。


095147584.jpg


我的前端实现 ~

用户点击的时候,我会从后端的api查看队列中的数目,以及有谁排在我的前面 ~

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
         $( "#dialog" ).hide();
         $( "#mailname" ).focus();
         $( "#service" ).click( function (){
                     $.ajax({
                      type:  "POST" ,
                      url:  "/queue" ,
                      data : $( "#form_service" ).serialize(),
                      dataType:  "html" ,
                       timeout: 5000 ,
                      error:  function (){
                           alert( 'nima,超时了' );
                      },
                      success:  function (data,status){
                         if ( data== "ok" ){
                           <!--  alert (data+status+ "成功了" );-->
                             var  a=$( "input[name=mailname]" ).val();
                             window.location.href= "/mailpost?mailname=" +a; }
                         else {
                              $( '#myModal' ).modal();
                             }
                         }
                     });
         });
});



后端的实现~

不用redis做队列的原因是,python调用队列的时候总是莫名的关闭,卸载安装了好多遍。。。怪事 ~  和powershell多线程一样都很怪~

安装配置memcached环境,简单点直接yum ~

需要编译安装的朋友,用下面的脚本~

1
2
3
4
5
6
7
8
9
10
11
12
wget https: //github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz
tar xzf libevent- 2.0 . 21 -stable.tar.gz
cd libevent- 2.0 . 21 -stable
./configure
make
make install
wget http: //memcached.googlecode.com/files/memcached-1.4.15.tar.gz
tar vxzf memcached- 1.4 . 15 .tar.gz
cd memcached- 1.4 . 15
./configure --prefix=/usr/local/webserver/memcached
make
make install


100923886.jpg

启动memcached 命令是:  /usr/local/memcached/bin/memcached -d -m 100 -c 1000 -u root -p 11211


1
2
3
4
5
6
7
8
9
10
-d 选项是启动一个守护进程
-m 是分配给Memcache使用的内存数量,单位是MB,默认64MB
-M  return  error on memory exhausted (rather than removing items)
-u 是运行Memcache的用户,如果当前为root 的话,需要使用此参数指定用户
-l 是监听的服务器IP地址,默认为所有网卡
-p 是设置Memcache的TCP监听的端口,最好是 1024 以上的端口
-c 选项是最大运行的并发连接数,默认是 1024
-P 是设置保存Memcache的pid文件
-f chunk size growth factor ( default 1.25 )
-I Override the size of  each  slab page. Adjusts max item size( 1.4 . 2 版本新增)


有朋友可能没有接触过memcached,也有没有用python操作memcached的。 我在这里就简单操作下,让大家瞅瞅哈~

python操作memcached需要安装 python-memcached模块

pip install python-memcached

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
import  memcache
  mc=memcache.Client([ '127.0.0.1:11211' ],debug= 0 )
  mc. set (“xiaorui.cc”,”fengyun”)
  value=mc. get (“xiaorui.cc”)
  mc. set (“another_key”, 3 )
  mc. delete (“another_key)
  mc. set (“key”,” 1 ″) #用于自动增量/减量的必须是字符串
  mc.incr(“key”)
  mc.decr(“key”)
  标准的使用memcache作为数据库缓存的方法如下:
  key=derive_key(obj)
  obj=mc. get (key)
  if  not obj:
  obj=backend_api. get (…)
  mc. set (obj)
  #现在可以操作obj


构造函数

delete(key,time=0)

删除某个键。time的单位是秒,确保特定时间内的set/update操作会失败。返回1成功,0失败。

incr(key,delta=1)

给自增量变量加上delta,默认为1。

decr(key,delta=1)

给自减量变量减去delta,默认为1。

add(key,val,time=0,min_compress_len=0)

添加一个键值对,内部调用_set()方法。

replace(key,val,time=0,min_compress_len=0)

替换值,内部调用_set()方法。

set(key,val,time=0,min_compress_len=0)

无条件的设置键值对。time设置超时,单位是秒。min_compress_len用于设置zlib压缩。内部调用_set()方法。

set_multi(mapping,time=0,key_prefix=”,min_compress_len=0)

设置多个键值对。

get(key)

获取值。出错则返回None。

get_multi(keys,key_prefix=”)

获取多个键的值,返回字典。keys为健明列表。key_prefix是键名前缀,可以最终构成key_prefix+key的完整键名。与set_multi中一样。


Memcached本身没有的实现的,但是高手还是多呀,有个高手开源了一个memcached队列的python实现方案。


RedQueue参考了github开源项目starling(ruby写的), twitter曾经使用伊做队列服务,后来改成了用scala写的scaling(kestrol) . Redqueue用python的高性能框架tornado写成。支持memcache协议, 也就是说伪装成一个memcache server,由于许多语言都有了memcache库,也就有了应用redqueue的土壤。 
redqueue是可以持久化的,使用日志文件记录所有的操作,当系统重启的时候,可以恢复没有处理的未超时任务重新处理。 这样对于server端的容错性有好处。更进一步的是,redqueue具有客户端容错性,客户通过get命令从队列中得到一个任务,使用delete删除这个任务,如果没有delete而因某种原因退出了,则该任务会被server重新塞入队列等待处理。

101232965.jpg


关于redqueue的python应用小demo ~

1
2
3
4
5
6
7
8
9
10
11
12
13
# 引入memcache模块
import  memcache
#初始化客户端
mc = memcache.Client([ '127.0.0.1:12345' ])  # 假设redqueue server守候在localhost的 12345 端口
# 发布一个项目到key myqueue中, 值为 "Hello world"
mc. set ( "xiaorui" "good" )
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                
# 消费者从queue server中取出一个任务, 并打印
print mc. get ( "xiaorui" )  # 应该是 good
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                
# 删除一个任务,必须做,否则server会认为客户端异常发生了,而重新队列处理该任务
# 什么时候客户端确认该任务已经确保执行了,就可以 delete 掉。在这之间,任务不会被其他客户端执行。
mc. delete ( "xiaorui" )

105833308.jpg

这个是作者给的过程:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
== Install and Run
  Install tornado and (optional) python-memcached  for  client testing
                                                                                                                                                                                                                                                                                                                                                                    
  Get the source from
  git@github.com:superisaac/redqueue.git
                                                                                                                                                                                                                                                                                                                                                                    
  Install
  % python setup.py install
  Make the log dir
  % mkdir -p log
  Run the server
  % redqueue_server.py
                                                                                                                                                                                                                                                                                                                                                                    
  For more options please run
  % redqueue_server.py --help
== Reserve/ delete  mode
    Reserve/ delete  mode  is  currently the sole mode, once an item  is  fetched, a  delete  request must be send later to mark the item  is  used, or  else  the item will be recycled back later.
    >>> mc. set ( 'abc' '123' )
    >>> v = mc. get ( 'abc' )
    >>>  if  is  not None:
    >>>     mc. delete ( 'abc' )


现在队列有了,我给大家说下,我那边是咋实现排队的~

当用户访问页面下一步的时候,我会判断队列,要是他前面有人在进行,我会给他重定向到最初的页面。当别人搞完了,他才可以的。

但是这样的话,还有个问题,那就是要是有5个人同时进了队列里面了,我给他们已经排序了,要是老大和老二,他不在进行了,老三的话,咋办。。。  这时候就需要配置队列里面的值和kv的一个值做时间的生效。  也就是说  老大和老二要是在指定的时间内没有完成的话,我会把他们踢出去,这样老三就成老大了。



 本文转自 rfyiamcool 51CTO博客,原文链接:http://blog.51cto.com/rfyiamcool/1330636,如需转载请自行联系原作者





相关文章
|
12天前
|
安全 前端开发 数据库
Python 语言结合 Flask 框架来实现一个基础的代购商品管理、用户下单等功能的简易系统
这是一个使用 Python 和 Flask 框架实现的简易代购系统示例,涵盖商品管理、用户注册登录、订单创建及查看等功能。通过 SQLAlchemy 进行数据库操作,支持添加商品、展示详情、库存管理等。用户可注册登录并下单,系统会检查库存并记录订单。此代码仅为参考,实际应用需进一步完善,如增强安全性、集成支付接口、优化界面等。
|
1月前
|
开发框架 数据建模 中间件
Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器是那些静悄悄的幕后英雄。它们不张扬,却能默默地为函数或类增添强大的功能。本文将带你了解装饰器的魅力所在,从基础概念到实际应用,我们一步步揭开装饰器的神秘面纱。准备好了吗?让我们开始这段简洁而富有启发性的旅程吧!
43 6
|
2月前
|
IDE 数据挖掘 开发工具
Python作为一种广受欢迎的高级编程语言,以其简洁的语法和强大的功能吸引了众多初学者和专业开发者
Python作为一种广受欢迎的高级编程语言,以其简洁的语法和强大的功能吸引了众多初学者和专业开发者
43 7
|
12天前
|
前端开发 搜索推荐 编译器
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
|
12天前
|
人工智能 编译器 Python
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
|
26天前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
105 5
|
1月前
|
测试技术 Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界中,装饰器是那些能够为我们的代码增添魔力的小精灵。它们不仅让代码看起来更加优雅,还能在不改变原有函数定义的情况下,增加额外的功能。本文将通过生动的例子和易于理解的语言,带你领略装饰器的奥秘,从基础概念到实际应用,一起开启Python装饰器的奇妙旅程。
44 11
|
1月前
|
Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器就像是给函数穿上了一件神奇的外套,让它们拥有了超能力。本文将通过浅显易懂的语言和生动的比喻,带你了解装饰器的基本概念、使用方法以及它们如何让你的代码变得更加简洁高效。让我们一起揭开装饰器的神秘面纱,看看它是如何在不改变函数核心逻辑的情况下,为函数增添新功能的吧!
|
2月前
|
设计模式 监控 程序员
Python中的装饰器:功能增强与代码复用的利器####
本文深入探讨了Python中装饰器的工作原理、应用场景及其在提升代码可读性、减少重复劳动方面的优势。不同于传统方法的冗长和复杂,装饰器提供了一种优雅且高效的方式来增强函数或方法的功能。通过具体实例,我们将揭示装饰器如何简化错误处理、日志记录及性能监控等常见任务,使开发者能够专注于核心业务逻辑的实现。 ####
|
2月前
|
机器人 计算机视觉 Python
Python作为一种高效、易读且功能强大的编程语言,在教育领域的应用日益广泛
Python作为一种高效、易读且功能强大的编程语言,在教育领域的应用日益广泛
62 5