Memcached操作

Posted 波波波波波

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Memcached操作相关的知识,希望对你有一定的参考价值。

标准协议和字段

Memcached的标准协议字段包含以下部分:

  • 键,key,任意字符,最大250字节,不能有空格和换行
  • 标志位,32比特,不能为0
  • 超时时间,单位是秒,0代表永不超时,最长30天,30天之后,就会出现一个类似于准确的时间戳
  • CAS值,64比特,唯一值,不重复
  • 任意字符,缓存中存储的字节数,也就是字节长度。

CAS值是可选项,通过-c可以禁用,对于一个项目还有其他很多属性值,但是这些属性值client都不会用到,所以也就不太关心了。

No reply不回复

在绝大多数的ASCII命令中,都支持不回复的,但是通常不建议在ASCII中使用这种协议,这样容易造成错误和请求对齐。之所以使用这种不回复的机制,就是为了避免当出现修改操作命令之后需要等待响应回复的等待时间的出现。

在二进制协议中,就是使用这种不回复的机制,如果client支持二进制协议,那就是相当好的。

存储命令

Set:最常用的命令,用来存储数据,修改已经存在的数据,新数据通常放在LRU顶部

Add:存储数据,前提是该数据在memcached中不存在,如果该数据已经在memcached中已经存在,那么add操作是会失败的,但是会将该数据移动到LRU的最顶部。

Replace:当数据存在时,才会去存储替换数据,基本上用不到。

Append:将新数据放在所有数据的最后面,但是不允许超过允许的最大长度,在管理列表时有点作用,该item必须要在memcached中存在,将值添加到原值的后面。

Prepend:和append类似,将新数据放在数据的前面。

Append和prepend实际上是修改键对应的值。

Cas:Check And Set (or Compare And Swap),当距离上一次读去数据之后,该数据备用被更新,才会去存储该数据,

Set设置name为键,12是一个标志位,不能有重复,默认情况下如果通过client去写,不用关心,client会自己定义,不能为0,后面的0是表示永不超时,4代表为设置的值的长度为4,超过4设置就会报错。

当对数据使用set进行修改时,会直接修改所有属性。

Append和prepend修改数据值

Memcached_client.set(\'name\',\'bobo\',time=0)
Memcached_client.add(\'name1\',\'bobo1\',time=0)
Memcached_client.append(\'name1\',\' bobo2\',time=0)
print(Memcached_client.get(\'name\'))
print(Memcached_client.get(\'name1\'))

检索获取数据

Get:用来检索数据,通过输入键key,memcached返回对应的值,可以同时获取多个键对应的值。

Gets:通过CAS值来检索数据,同时返回给item的CAS值。

 

删除数据

Delete:如果memcached中存在,就删除对应的键值对。

 

排序

如果item对象是一个64位整型存储的,可以通过incr/decr来进行排序,只能对正数进行排序,不能对负数进行排序。

 

超时flush_all

将memcached中的数据全部标记为不可用,通常情况下会跟一个参数,也就是时间,大概多久之后数据失效,这个操作不会影响服务的正常运行,也不会清空cache,只是将这些数据标记为不可用。

 

Memcached安全思考

Memcached作为一个中间件,能加速访问,由于并不带认证,容易受到攻击破环,所以不建议将memcached放在外网或者是所有人都能访问到的地方,如果只是为了加速用户访问,建议放在服务器后面,由服务器去调度memcached,如果memcached和服务安装在同一台服务器上,尽量用127.0.0.1来启动服务。如果是跨主机的通信,建议还是使用防火墙来做限制。

以上是关于Memcached操作的主要内容,如果未能解决你的问题,请参考以下文章

python操作memcached

Python操作memcached

Memcached基本操作

python 操作Memcached

Memcached数据操作

python之Memcached 安装及操作