Python-memcached的使用用法

系统 1492 0

 

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网页优化小记


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论