memcache基本使用
来源:互联网 发布:清华大学软件学院校友 编辑:程序博客网 时间:2024/06/06 03:00
Memcache是什么
Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力。
它可以应对任意多个连接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached自管理这些HashTable。
Memcache官方网站:http://www.danga.com/memcached,更多详细的信息可以来这里了解
为什么会有Memcache和memcached两种名称?
其实Memcache是这个项目的名称,而memcached是它服务器端的主程序文件名,知道我的意思了把~~~~。一个是项目名称,一个是主程序文件名,在网上看到了很多人不明白,于是混用了。
Memcache的安装
分为两个过程:memcache服务器端的安装和memcached客户端的安装。
所谓服务器端的安装就是在服务器(一般都是Linux系统)上安装Memcache实现数据的存储
所谓客户端的安装就是指PHP(或者其他程序,Memcache还有其他不错的api接口提供)去使用服务器端的Memcache提供的函数,需要php添加扩展。
安装memcache
1.用管理员身份进入cmd命令模式
2.将memcache文件放入localhost(域名)文件当中
3.cmd命令 cd /phpstudy/memcache memcache -d install 安装成功之后在任务管理器中打开,启动应用
PHP的Memcache
< ?php //连接 $mem = new Memcache; $mem->connect("127.0.0.1", 11211); //保存数据 $mem->set('key1', 'This is first value', 0, 60); $val = $mem->get('key1'); echo "Get key1 value: " . $val ."<br />"; //替换数据 $mem->replace('key1', 'This is replace value', 0, 60); $val = $mem->get('key1'); echo "Get key1 value: " . $val . "<br />"; //保存数组 $arr = array('aaa', 'bbb', 'ccc', 'ddd'); $mem->set('key2', $arr, 0, 60); $val2 = $mem->get('key2'); echo "Get key2 value: "; print_r($val2); echo "<br />"; //删除数据 $mem->delete('key1'); $val = $mem->get('key1'); echo "Get key1 value: " . $val . "<br />"; //清除所有数据 $mem->flush(); $val2 = $mem->get('key2'); echo "Get key2 value: "; print_r($val2); echo "<br />"; //关闭连接 $mem->close(); ?>
如果正常的话,浏览器将输出:
Get key1 value: This is first value
Get key1 value: This is replace value
Get key2 value: Array ( [0] => aaa [1] => bbb [2] => ccc [3] => ddd )
Get key1 value:
Get key2 value:
代码讲解
连接到我们的Memcache服务器端,第一个参数是服务器的IP地址,也可以是主机名,第二个参数是Memcache的开放的端口:
$mem->connect("192.168.0.200",12000);
保存一个数据到Memcache服务器上,第一个参数是数据的key,用来定位一个数据,第二个参数是需要保存的数据内容,这里是一个字符串,第三个参数是一个标记,一般设置为0或者MEMCACHE_COMPRESSED就行了,第四个参数是数据的有效期,就是说数据在这个时间内是有效的,如果过去这个时间,那么会被Memcache服务器端清除掉这个数据,单位是秒,如果设置为0,则是永远有效,我们这里设置了60,就是一分钟有效时间:
$mem->set(‘key1‘,‘This is first value’,0, 60);
从Memcache服务器端获取一条数据,它只有一个参数,就是需要获取数据的key,我们这里是上一步设置的key1,现在获取这个数据后输出输出:
$val = $mem->get(’key1′); echo "Get key1 value: " . $val;
现在是使用replace方法来替换掉上面key1的值,replace方法的参数跟set是一样的,不过第一个参数key1是必须是要替换数据内容的key,最后输出了:
$mem->replace(‘key1′,‘This is replace value’,0, 60); $val = $mem->get(‘key1′); echo "Get key1 value: " . $val;
现在删除一个数据,使用delte接口,参数就是一个key,然后就能够把Memcache服务器这个key的数据删除,最后输出的时候没有结果
`$mem->delete(‘key1′); $val = $mem->get(‘key1′); echo "Get key1 value: " . $val ."<br>"; `
最后我们把所有的保存在Memcache服务器上的数据都清除,会发现数据都没有了,最后输出key2的数据为空,最后关闭连接
$mem->flush(); $val2 = $mem->get(‘key2′); echo "Get key2 value: "; print_r($val2); echo "<br>";
封装类
<span style="color:#333333;"><?php header("content-type:text/html;charset=utf-8"); class mem{ function __construct($name){ $this->mem=new Memcache; $this->mem->connect("localhost",11211); $this->name=$name; } //删除memcache中的数据 function deletes(){ $this->mem->delete($this->name); } //获得数据 function gets(){ return $this->mem->get("$this->name"); } //保存数据 function sets(){ $this->mem ->set($this -> name,$this -> name,0,0); } //清楚memcache中的数据 function clean(){ $this->mem->flush(); } } $name = $_GET['name']; $m = new mem($name); $m -> sets(); echo $m -> gets();</span>
- memcache基本使用
- memcache基本使用
- memcache 基本使用
- Redis, Memcache 基本使用
- memcache 基本使用-已测试
- Memcache学习总结2-Memcache的使用基本介绍
- memcache配置、基本使用与集群配置
- memcache配置、基本使用与集群配置
- memcache配置、基本使用与集群配置
- Ubuntu下Memcache的安装与基本使用
- liunx下安装与基本使用php内存缓存Memcache
- Ubuntu下Memcache的安装与基本使用
- Ubuntu下Memcache的安装与基本使用
- ubuntu下memcache的安装与基本使用
- memcache 使用
- memcache 使用
- memcache使用
- Java Memcache基本应用
- spark运行原理和RDD解密
- shader 光照模型,半角向量
- 获取指定Activity的截屏,保存到png文件
- java Number 方法 运算符
- spring的annotation
- memcache基本使用
- XPP3-一个非常快的XML解析器
- 事件分发机制原理
- 找不到 constraint-layout:1.0.0-alpha3
- iOS文件拷贝实现
- Network Link Conditioner模拟不同网络环境
- Java中的内存堆栈
- git入门命令笔记
- ECCV2016 部分文章