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 //存在

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

PHP和Memcached - Memcached的介绍及常用命令的更多相关文章

  1. Linux的简单介绍和常用命令的介绍

    Linux的简单介绍和常用命令的介绍 本说明以Ubuntu系统为例 Ubuntu系统的安装自行百度,或者参考http://www.cnblogs.com/CoderJYF/p/6091068.html ...

  2. redis 介绍和常用命令

    redis 介绍和常用命令 redis简介 Redis 是一款开源的,基于 BSD 许可的,高级键值 (key-value) 缓存 (cache) 和存储 (store) 系统.由于 Redis 的键 ...

  3. webpack 介绍 & 安装 & 常用命令

    webpack 介绍 & 安装 & 常用命令 webpack系列目录 webpack 系列 一:模块系统的演进 webpack 系列 二:webpack 介绍&安装 webpa ...

  4. redis学习(二) redis数据结构介绍以及常用命令

    redis数据结构介绍 我们已经知道redis是一个基于key-value数据存储的数据结构数据库,这里的key指的是string类型,而对应的value则可以是多样的数据结构.其中包括下面五种类型: ...

  5. Redis介绍及常用命令

    一 Redis介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起,Redis的开发 ...

  6. 转:Redis介绍及常用命令大全

    一 Redis介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起,Redis的开发 ...

  7. LVM基本介绍与常用命令

    一.LVM介绍LVM是 Logical Volume Manager(逻辑卷管理)的简写,它是Linux环境下对磁盘分区进行管理的一种机制LVM - 优点:LVM通常用于装备大量磁盘的系统,但它同样适 ...

  8. vim编辑器介绍及其常用命令

    vim简单的介绍 Vim 编辑器是一个模式编辑器 . 这意味着在不同状态下编辑器有不同的行为模式 . 两个基本的模式是 Normal 模式和 Insert 模式 ,还有可视模式. 在 Normal 模 ...

  9. [Python]Conda 介绍及常用命令

    一.介绍 Anaconda 是一个用于科学计算的 Python 发行版,支持 Linux, Mac, Windows, 包含了众多流行的科学计算.数据分析的 Python 包.其使用conda系统进行 ...

随机推荐

  1. 计蒜客 UCloud 的安全秘钥 ——(hash)

    题目链接:https://nanti.jisuanke.com/t/15769. 题意是求可以变换位置以后相同的子串有多少个,那么做法是只要每个数字的平方和,立方和以及四次方和都相同就可以了. 代码如 ...

  2. BZOJ4237稻草人——单调栈+CDQ分治

    题目描述 JOI村有一片荒地,上面竖着N个稻草人,村民们每年多次在稻草人们的周围举行祭典. 有一次,JOI村的村长听到了稻草人们的启示,计划在荒地中开垦一片田地.和启示中的一样,田地需要满足以下条件: ...

  3. Docker:Docker Compose 详解

    Docker Compose 概述与安装? 前面我们使用 Docker 的时候,定义 Dockerfile 文件,然后使用 docker build.docker run 等命令操作容器.然而微服务架 ...

  4. 总结js常用的dom操作(js的dom操作API)

    转载:https://www.haorooms.com/post/js_dom_api 前言 很多同学用惯了jquery操作dom,让他们用js操作的时候,常常力不从心,本文总结了常用的js的dom操 ...

  5. arcgis python 布局中所有元素信息报告

    # Author: ESRI # Date: July 5, 2010 # Version: ArcGIS 10.0 # Purpose: This script generates a report ...

  6. flutter 引入第三方 Icon 图标(以阿里图标库为例)

    在fluttter中引入第三方图标库的具体方法: 1.在阿里图标库选好需要用的图标,添加进购物车将选好的图标打包下载到本地(下载代码),复制iconfont.ttf文件到项目中 2.存放途径:lib/ ...

  7. kafka和zookeeper的配置文件优化配置

    zookeeper的配置 日志自动清理这两个参数都是在zoo.cfg中配置的:    autopurge.purgeInterval 这个参数指定了清理频率,单位是小时,需要填写一个1或更大的整数,默 ...

  8. spark简单文件配置

    cd /usr/local/spark/spark-2.2.1-bin-hadoop2.7/conf cp slaves.template slaves cp spark-env.sh.templat ...

  9. mysqlcheck修复工具

    mysqlcheck工具可以检查.修复.优化和分析MyISAM引擎的表,实际上是集成了Mysql中的check.repair.analyze.tmpimize的功能. mysqlcheck共军存在于m ...

  10. AFN使用etag进行网络缓存

    前提:后台返回的接口带etag 第一步 - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:( ...