Memcached API

  • 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")

  • decr(key,delta=1)

自减变量减去delta,默认减1

Python操作Memcached

前提:已安装Memcached

linux下安装python-memcached

apt-get install python-memcached

简单示例

import memcache

mc = memcache.Client(['127.0.0.1:12000'],debug=False)
mc.set("foo","bar")
value = mc.get("foo")
print(value) #输出bar
# debug=True表示运行出现错误时,可以显示错误信息,正式环境可以不加

在python网页应用中的示例

import memcache
mc = memcache.Client(['127.0.0.1:11211'], debug=0)

memcache其实就是一个map结构,最常使用的就是两个函数了:

  • 第一个就是set(key,value,timeout),这个很简单就是把key映射到value,timeout指的是什么时候这个映射失效
  • 第二个就是get(key)函数,返回key所指向的value

对一个sql查询,如果要对结果做缓存,可以这么做:

sql = 'select count(*) from verycd'
c = sqlite3.connect('verycd.db').cursor()
 
#原来的处理方式
c.execute(sql)
count = c.fetchone()[0]
 
#现在的处理方式
from hashlib import md5
key=md5(sql)
count = mc.get(key)
if not count:
c.execute(sql)
count = c.fetchone()[0]
mc.set(key,count,60*5) #存5分钟

#md5是为了让key分布更均匀。

refer:

python---Memcached

Python-memcached的基本使用

30分钟3300%性能提升――python+memcached网页优化小记

最新文章

  1. Java泛型及实践
  2. js公用方法
  3. [修正] Berlin Firemonkey Windows 控件左方显示虚线问题
  4. ThinkPHP3.2.3使用cli命令行模式
  5. 解决Tomcat7“At least one JAR was scanned for TLDs yet contained no TLDs”问题
  6. [Tomcat 源码分析系列] (一) : Tomcat 启动脚本-startup.bat
  7. JS去掉数组的重复项
  8. mysql导入sql文件
  9. Web app 的性能瓶颈与性能调优方法
  10. eclipse中改变默认的workspace的方法及说明
  11. Django设置
  12. Template 使用注意问题和范例
  13. C++简介
  14. JAVA I/O使用方法(转)
  15. 分享Java的9个知识点
  16. python 基本运算符
  17. valueof toString
  18. Sql Server中sql语句自己主动换行
  19. codevs 3022 西天收费站
  20. python给字典排序

热门文章

  1. PostgreSQL 之 CREATE FUNCTION
  2. ffprobe读取音视频元数据信息,json格式输出
  3. 我的dbtreeview–treeview直接连接数据表_delphi教程
  4. windows配置apache支持https
  5. Linux下切换用户根目录的指令
  6. 【leetcode_easy】541. Reverse String II
  7. groupby+agg
  8. (4)Linux命令分类汇总(13~16)
  9. 基于Keras 的VGG16神经网络模型的Mnist数据集识别并使用GPU加速
  10. Git速成学习第三课:创建与合并分支