Python-memcached的基本使用 - Flynewton成长点滴 - 开源中国社区

Python-memcached的基本使用 -
Flynewton成长点滴 - 开源中国社区

Python-memcached的基本使用 发表于3年前(2010-12-04 00:02)  
阅读(9601) | 评论(3) 12人收藏此文章, 我要收藏 赞1 python memcached
想学Python,又想研究下memcached的客户端,于是拿Python-memcached研究研究~~~ 1.memcached的安装
请参考本博另一文章《Linux下安装memcached》 启动一个memcached实例:memcached -m 10 -p 12000
2.Python-memcached安装
到ftp://ftp.tummy.com/pub/python-memcached/下载最新版本的API,并解压tar包 输入python
setup.py install命令进行安装 3.小例子演示 将memcached.pyc拷贝到工作目录 #!/usr/bin/env
python import memcache mc = memcache.Client([‘127.0.0.1:12000‘],debug=0)
mc.set("foo","bar") value = mc.get("foo") print value 输出得到bar
4.Python-memcached API总结 整个memcache.py只有1241行,相当精简 主要方法如下:
@set(key,val,time=0,min_compress_len=0)
无条件键值对的设置,其中的time用于设置超时,单位是秒,而min_compress_len则用于设置zlib压缩(注:zlib是提供数据压缩用的函式库)
@set_multi(mapping,time=0,key_prefix=‘‘,min_compress_len=0)
设置多个键值对,key_prefix是key的前缀,完整的键名是key_prefix+key, 使用方法如下
  >>> mc.set_multi({‘k1‘ : 1, ‘k2‘ : 2},
key_prefix=‘pfx_‘) == []   >>> mc.get_multi([‘k1‘,
‘k2‘, ‘nonexist‘], key_prefix=‘pfx_‘) == {‘k1‘ : 1, ‘k2‘ : 2}
@add(key,val,time=0,min_compress_len=0) 添加一个键值对,内部调用_set()方法
@replace(key,val,time=0,min_compress_len=0) 替换value,内部调用_set()方法
@get(key) 根据key去获取value,出错返回None @get_multi(keys,key_prefix=‘‘)
获取多个key的值,返回的是字典。keys为key的列表 @delete(key,time=0)
删除某个key。time的单位为秒,用于确保在特定时间内的set和update操作会失败。如果返回非0则代表成功
@incr(key,delta=1) 自增变量加上delta,默认加1,使用如下 >>> mc.set("counter",
"20")   >>> mc.incr("counter") 21 @decr(key,delta=1)
自减变量减去delta,默认减1 5._set方法 很多方法内部都调用了_set方法,其源码如下: def _set(self, cmd,
key, val, time, min_compress_len = 0): self.check_key(key) server, key =
self._get_server(key) if not server: return 0 self._statlog(cmd)
store_info = self._val_to_store_info(val, min_compress_len) if not
store_info: return(0) if cmd == ‘cas‘: if key not in self.cas_ids:
return self._set(‘set‘, key, val, time, min_compress_len) fullcmd = "%s
%s %d %d %d %d\r\n%s" % ( cmd, key, store_info[0], time, store_info[1],
self.cas_ids[key], store_info[2]) else: fullcmd = "%s %s %d %d %d\r\n%s"
% ( cmd, key, store_info[0], time, store_info[1], store_info[2]) try:
server.send_cmd(fullcmd) return(server.expect("STORED") == "STORED")
except socket.error, msg: if isinstance(msg, tuple): msg = msg[1]
server.mark_dead(msg) return 0 注: memcached 的客户端使用TCP链接与服务器通讯,
一个运行中的memcached服务器监视一些端口,
客户端连接这些端口,发送命令到服务器,读取回应,最后关闭连接。(具体命令请参考《Memcached 协议中文版》)  
6.python-memcached线程安全
本部分转自http://weavesky.com/2009/01/22/is-python-memcached-threadsafe/
python-memcached是不是线程安全的 答案是肯定的,前提你在使用Python 2.4+和python-memcached 1.36+
为什么我们需要线程安全的memcached
client,因为我们的实际应用一般是多线程的模型,例如cherrypy、twisted,如果python-memcached不是线程安全的话,引起的问题不仅仅是并发修改共享变量这么简单,是外部socket链接的数据流的混乱
python-memcached怎么实现线程安全的呢?查看源代码看到 try: # Only exists in Python 2.4+
from threading import local except ImportError: # TODO: add the
pure-python local implementation class local(object): pass class
Client(local):  
很取巧的让Client类继承threading.local,也就是Client里面的每一个属性都是跟当前线程绑定的。实现虽然不太优雅,但是很实在。但是别以为这样就可以随便在线程里面用python-memcached了,因为这种thread
local的做法,你的应用必须要使用thread
pool的模式,而不能不停创建销毁thread,因为每一个新线程的创建,对于就会使用一个全新的Client,也就是一个全新的socket链接,如果不停打开创建销毁thread的话,就会导致不停的创建销毁socket链接,导致性能大量下降。幸好,无论是cherrypy还是twisted,都是使用了thread
pool的模式


Python-memcached的基本使用 - Flynewton成长点滴 - 开源中国社区,布布扣,bubuko.com

时间: 2024-08-25 15:19:24

Python-memcached的基本使用 - Flynewton成长点滴 - 开源中国社区的相关文章

python   memcached

管理服务  start   stop  status  restart 启动脚本 name memcached program  /usr/bin/memcached pidfile args #参数  -u -p -m -c work-dir python -m SimpleHTTPServer #启动一个小型的web服务 函数 pass占位 脚本名称+num  直接进入num行 pidof  memcached  查看进程num 读成字典 lines列表变成字典 dict([i.strip(

成长点滴:我不知道该说些什么?

家里有点事,最近回了趟家,     火车上也不知道什么情况,人好像不比春运时候少,刚开始邻座之间还闲聊几句,慢慢到了深夜,都疲倦的不行了,摆着各种不舒服的让自己稍微舒服的姿势睡着了,依窗打呼噜的,趴桌子流鼾喇子的,躺在座椅底下.过道里,摆的四平八歪!脱了鞋臭味搅和着方便面味,哎呀,这可能就是纯百姓的生活旅途吧!拖着疲惫不坎的身子终于熬到了西安,我走了,你们继续,呵呵! 窗外下着毛毛细雨,大巴车大山里颠晃了四个多小时,终于到了村口,这时候村里的雨点好像比城里的还要大些,半个村子或旧或新的房子被拆成

python模拟登录开源中国

我的个人博客( 肥龙的博客)发表了新文章了! 欢迎大家过来阅读,以下是文章的连接地址 http://www.comingcode.com/?p=371 继上一篇文章模拟登录百度空间(http://www.comingcode.com/?p=357)后,为了多点推广自己的博客,通过上网搜索资料和分析http数据包,我再次使用python模拟了开源中国的登录操作,能够发表博客同时也能发送动弹. 具体的实现过程也是和登录百度空间的差不多,都是需要去分析http发送的数据包内容. 通过这两篇文章的模拟登

Python + Selenium 自动发布文章(一):开源中国

https://blog.csdn.net/qq_28804275/article/details/80891949 https://blog.csdn.net/qq_28804275/article/details/80891949Python + Selenium 自动发布文章系列:Python + Selenium 自动发布文章(一):开源中国Python + Selenium 自动发布文章(二):简书Python + Selenium 自动发布文章(三):CSDNPython + Sel

Python Memcached Script

介绍 利用 python 书写了 memcached 的启动等一类操作 尽量的实现脚本的复用性,以及脚本的可扩展性,已达到一劳永逸的效果, 并且添加了 memcached 监控搭建 memcached 操作代码 #!/usr/bin/env python # _*_coding:utf-8_*_ # Author: "Edward.Liu" # Author-Email: [email protected] import psutil import argparse import sy

34. Python Memcached 安装 集群

1.Memcache 安装 安装过程略,查询官网有安装方法. 官方网站下载地址:http://memcached.org/downloads memcache简介 Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载. 它通过在内存中缓存数据和对象减少读取数据库的次数,从而提高动态.数据库驱动网站的速度. Memcached基于一个存储键/值的hashmap. 其守护进程(daemon)是用C语言写的,但是客户端可以用任何语言来编写,并通过memcached

python—memcached启动脚本

一.一般模式 启动选项:start.stop.restart.status #!/usr/bin/env python #encoding:utf-8 import sys import os from subprocess import Popen, PIPE class Process(object):     '''memcached rc script'''     def __init__(self,name,program,argv,workdir):  # 初始化类,包含:self

一位年轻而优秀的.NET开发者的成长点滴

一,社区的小圈子 今年3月的一次技术交流活动上,那是我们.NET技术社区第一次组织线下活动,由于没什么经验,所以活动组织得比较仓促,内容也比较一般,效果还是有点欠缺.当然,活动本身是必要的,这次活动上有幸认识了许多长沙的优秀开发者,这让我非常的高兴. 事实上搞技术活动,与其说是交流技术,倒不如说是扩大圈子,交流感情,认识更多的朋友.毕竟每个职场人往往圈子都是固定的,哪怕是在大公司,真正经常来往的朋友其实也不过三两人而已.但是在北上广深的大城市,往往有时候刚刚认识几个朋友,对方可能就离开了,这也是

如果你喜欢Python 那么你不得不知的几个开源项目

1.Trac Trac拥有强大的bug管理 功能,并集成了Wiki 用于文档管理.它还支持代码管理工具Subversion ,这样可以在 bug管理和Wiki中方便地参考程序源代码. Trac有着比较强大的插件系统,可以通过插件来实现各种各样的功能,比如支持Git,或者增加自己的一些语法等等. 如果你想了解wiki是如何实现的,或者svn是如何集成的,那么你可以看看这个项目的源码. 2.Docutils Docutils项目的主要是为了创造一套将纯文本转换为一些常用格式的工具,这些常用格式包括: