PHP和Memcached - Memcached的介绍及常用命令

时间:2024-11-07 14:06:32

1、什么是Memcached

*开源的,高性能,分布式内存对象缓存系统,分布式是基于客户的缓存系统,服务器之间是不相互通讯的。

2、Memcached的使用场景

  • 储存session。
  • 缓存数据。
  • 解决MySQL数据库主从中继高并发的场景(比如:抢票、订单支付、订单回调、秒杀。

3、常用命令

set命令

  • 将value(数据值)储存到key(键)中,默认flags是0,保存时间是time's,如果time=0表示永远(不超过30天),在缓存中的字节长度是bytes,如果设置了noreply=noreply则没有提示输出,在回车后设置value。
  • 如果key存在,则value覆盖。
  • 如果覆盖value,那么key的token_id也会发生改变。
  • 为保证服务的最佳性能,key<512Bytes, value < 1MB。
  • 语法结构:set key flags time bytes noreply(可选) value。
set k1   5    //语法结构,set key flags time bytes
abcde //回车后输入value值,注意,字节大小切记设计规范,不符合字节大小的是需要一直输入,直到符合字节大小为止
STORED //返回状态

get / gets命令

  • 获取储存在缓存中的对应key值的value,如果key不存在,返回空。
  • gets多获取一个token_id
  • 语法结构:get / gets key1, key2, key3......
get k1    //语法结构
VALUE k1 5 //获取到看k1的配置信息
abcde //获取到k1的value
END //结束

现在,我们在看一下gets这个命令

gets k1
VALUE k1 63 //63就是k1的唯一标识token_id
abcde
END

delete命令

  • 删除一个key
  • 语法结构:delete key
delete k1    //语法结构
DELETED //删除成功

prepend / append命令

  • 在指定key里面的value前面/后面增加数据
  • 语法结构:prepend / append set key flags time bytes noreply(可选) value
set k1   5  //设置一个k1,value是world
world
STORED get k1 //查看一下确实是world
VALUE k1
world
END prepend k1 6 //在k1前面增加hello
hello
STORED append k1 2 //在k1后面增加 !
!
STORED get k1 //查看k1,value是hello world!,注意,字节长度也变成了13
VALUE k1
hello world !
END

incr/decr命令

  • 对指定的key里面的value自增 / 自减指定数值
  • 必须是整型
  • 支持多线程同步
  • 语法结构:incr / decr key num
set k1   1    //设置k1value值为5

STORED

incr k1 5    //自增5,输出10

decr k1 2    //自减2,输出8

add命令

  • 跟set命令用法一样
  • 如果key存在,则不能更新value
  • 支持多线程同步
  • 语法结构:add key flags time bytes noreply(可选) value

cas命令

  • 进行token_id进行检查,如果token_id等于key的token_id,则设置value
  • 支持多线程同步
  • 语法结构:cas key flags time bytes token_id noreply(可选) value
set k1   5    //设置一个k1
abcde
STORED gets k1 //获取token_id 72
VALUE k1
abcde
END cas k1 72 //根据token_id进行修改
aaa
STORED //成功 gets k1 //查看k1 修改成功 token_id变更为了73
VALUE k1
aaa
END cas k1 70 //使用错误的token_id,无法修改
asdfg
EXISTS //存在

如有错误请纠正......