在php中使用Memcache
在上一篇博客中我写到了memcache的安装和管理,在这一篇博客中我将写到的是在php中如何使用memcache。
一、安装memcache扩展
首先我们通过phpinfo()函数查看一下我们当前的php环境是否支持memcache扩展,在服务器的根目录下新建一个文件info.php,在文件中写入
1
2
|
<?php phpinfo(); |
然后在浏览器中输入 http://localhost/info.php 访问,然后查找是否有memcache扩展,一般我们的服务器默认是没有安装memcache扩展的,所以还是得我们自己来安装。我们先到网上下载php_memcache.dll文件,把文件拷贝到php扩展目录下(我的是php5/ext/),在扩展目录下加上这个文件还没完成,我们要在php的配置文件php.ini文件中加入extension=php_memcache.dll,php环境会自动找到php扩展目录将这个扩展加到php环境中,这个时候我们再重启apache,然后再来访问 http://localhost/info.php ,就可以看到
这就说明我们的memcache扩展安装好了!我们再查看php手册,发现memcache扩展的使用有两种方式,第一种是面向过程的使用方式,还有一种是面向对象的使用方式,而我们一般常用的是面向对象的方式。
二、memcache的使用实例
直接贴代码了!
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
<?php //实例化memcache类 $mem = new Memcache; //连接memcache服务器(参数为服务器IP, 端口), //pconnect--表示持续连接 $mem ->connect( 'localhost' , 11211); //addserver表示增加memcache服务器, //多个memcache服务器可以实现分布式缓存 //$mem->addsever('www.pccxin.com', 11211); //$mem->addsever('www.frontu.net', 11211); //向memcache服务器中增加元素 //bool Memcache::add ( string $key , //mixed $var [, int $flag [, int $expire ]] ) //参数为 键名, 值(字符串|数组|对象), //使用 MEMCACHE_COMPRESSED 标记对数据进行压缩(使用zlib), // 保存时间(单位秒) $mem ->add( 'mystr' , 'This is my first memcache test!' , MEMCACHE_COMPRESSED, 3600); //add不会重复添加,要想改变值可用replace(),或者set //$mem->add('mystr', 'This is my first memcache test!', MEMCACHE_COMPRESSED, 3600); //向服务器中保存数据 $mem ->set( 'mystr' , 'This is my second memcache test!' , MEMCACHE_COMPRESSED, 3600); //从服务端删除一个元素 //$mem->delete('mystr'); //清洗(删除)已经存储的所有的元素 //$mem->flush(); //获取memcache中的数据 echo $mem ->get( 'mystr' ). '<br />' ; //向memcache服务器中增加元素 $mem ->add( 'myarr' , array ( '1' => 'aaa' , '2' => 'bb' , '3' => 'cc' ), MEMCACHE_COMPRESSED, 3600); var_dump( $mem ->get( 'myarr' )); echo '<br />' ; class Person{ var $name = 'shawnking' ; var $sex = '男' ; } //向memcache服务器中增加元素 $mem ->add( 'myobj' , new Person); var_dump( $mem ->get( 'myobj' )); echo '<br />' ; //获取memcache的版本信息 echo 'Version:' , $mem ->getVersion(); //得到memcache的参数信息 echo '<pre>' ; print_r( $mem ->getStats()); echo '</pre>' ; //关闭到memcached服务端的连接。这个函数不会关闭持久化连接, // 持久化连接仅仅会在web服务器关机/重启时关闭。与之对应的,你也可以使用 $mem ->close(); |
三、php在什么地方使用memcache
a、数据库中读出来的数据(select) 使用memcache处理
通常情况下我们访问一次页面php就会连接一次数据库,就会到数据库中读取数据,如果访问量大的时候数据库就无法承受压力了,我们使用memcache的话,只要页面第一次被访问php就会把数据存到memcache服务器中,并且设定一个过期时间,这样在过期时间之前都不需要去数据库读取数据,这个可以大大提成网站性能(我们memcache的数据是存在内存中的,所以读取起来非常快)。下面我就贴出在数据库中使用memcache的示例代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
<?php //实例化一个memcache对象 $mem = new Memcache; //连接memcache服务器 $mem ->connect( 'localhost' , 11211); /** * 注意: * 1、同一个项目安装两次,key要有前缀 * $key = 'a_test'; * $key = 'b_test'; * 2、 用sql语句作为下标,这样可以让相同sql语句的数据只要存一份到memcache */ $sql = 'SELECT * FROM test' ; $key = substr (md5( $sql ), 10, 8); //从memcache服务器获取数据 $data = $mem ->get( $key ); //判断memcache是否有数据 if ( ! $data ){ $mysqli = new mysqli( 'localhost' , 'root' , '123456' , 'testdb' ); $result = $mysqli ->query( $sql ); $data = array (); while ( $row = $result ->fetch_assoc() ){ $data [] = $row ; } $result ->free(); //释放内存 $mysqli ->close(); //断开mysql连接 //向memcache服务器存储数据,还要设置失效时间(单位为秒) $mem ->set( $key , $data , MEMCACHE_COMPRESSED, 3600); } print_r( $data ); $mem ->close(); //关闭memcache连接 b、在会话控制session中使用 将session信息写入到memcache服务器当中 <?php /** * session保存到memcache类 */ class MemSession{ private static $handler = null; private static $lifetime = null; private static $time = null; const NS = 'session_' ; /** * 初始化函数 */ private static function init( $handler ){ self:: $handler = $handler ; self:: $lifetime = ini_get ( 'session.gc_maxlifetime' ); self:: $time = time(); } public static function start(Memcache $memcache ){ self::init( $memcache ); session_set_save_handler( array ( __CLASS__ , 'open' ); array ( __CLASS__ , 'close' ); array ( __CLASS__ , 'read' ); array ( __CLASS__ , 'write' ); array ( __CLASS__ , 'destrory' ); array ( __CLASS__ , 'gc' ); ); session_start(); } public static function open( $path , $name ){ return true; } public static function close(){ return true; } public static function read( $PHPSESSID ){ $out = self:: $handler ->get(self:: $session_key ( $PHPSESSID )); if ( $out === false || $out = null ) return '' ; return $out ; } public static function write( $PHPSESSID , $data ){ $method = $data ? 'set' : 'replace' ; return self:: $handler -> $method (self:: $session_key ( $PHPSESSID ), $data , MEMCACHE_COMPRESSED, self:: $lifetime ); } public static function destroy( $PHPSESSID ){ return sele:: $handler -> delete (self:: $session_key ( $PHPSESSID )); } public static function gc( $lifetime ){ return true; } private static session_key( $PHPSESSID ){ $session_key = self::NS. $PHPSESSID ; return $session_key ; } } $memcache = new Memcache; $memcache ->connect( 'localhost' , 11211) or die ( 'could not connect!' ); MemSession::start( $memcache ); |
四、memcache的安全(不让别人访问)
1、内网连接
2、设置防火墙
iptables -A INPUT -p tcp -dport 11211 -j DROP 来拒绝全部的访问,
再设置可以访问的IP
iptables -A INPUT -p tcp -s 192.168.1.111 -dport 11211 -j ACCEPT
iptables -A INPUT -p udp -s 192.168.1.111 -dpost 11211 -j ACCEPT
在php中使用Memcache的更多相关文章
- NHibernate中使用memcache二级缓存
在NHibernate中使用memcache二级缓存 一.Windows下安装Memcache 1. 下载 http://jehiah.cz/projects/memcached-win32/ ...
- (转)java中使用memcache
背景:公司项目中使用java和memcache相结合来搭建缓存,所以要了解下缓存的基础知识! 1 了解memcache 1.1 基础知识 什么是Memcache? Memcache集群环境下缓存解决方 ...
- Ubuntu中安装memcache并且在Python中连接memcache
1.安装memcache到Ubuntu. PS:依赖libevent,需要提前安装 yum install libevent-devel #centos中使用这个 apt-get install li ...
- php项目中使用memcache
memcache为分布式内存缓存系统,通过在内存中存取数据和对象减少对数据库的访问从而减轻数据库的负载,memcache分为客户端和服务端,服务端为C实现,有现成的服务端应用程序,无需开发,只需要配置 ...
- PHP中的Memcache详解
一.Memcache简介 Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力.它可以应 ...
- 安装memcached服务器和PHP中添加memcache拓展模块
Memcached是一个高性能的分布式内存对象缓存系统,用于动态web应用以减轻数据库的负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提拱动态 数据驱动网站的速度. memcached ...
- Yii 框架中安装 memcache 及配置和测试
安装php_memcache.dll扩展 1.首先将php_memcache.dll文件放入E:\server\php\ext目录下 (php_memcache.dll下载地址:http://wind ...
- php中安装memcache
1.查看php的版本(我的是5.6) 2.打开phpinfo查看第四行 3.然后选择要安装的文件 4.复制到 ext中 复制后 5.打开配置文件php.ini 把 extension=php_memc ...
- 在yii中使用memcache
yii中可以很方便的使用memcache 一.配置在main.php的components中加入cache配置 array( 'components'=>array( 'cache'=>a ...
随机推荐
- ACM1024动态规划
#include <cstdio> #include <algorithm> #define FI(a, b, c) for(int a = (b); a <= (c); ...
- Struts1、Struts2和SpringMVC剖析【转载】
前段框架用了不少,今天就来做个总结.网上关于Struts1.Struts2.SpringMVC的文章有很多,这里的内容就是基于它们,来做个比较. 这三个框架是按照上面的顺序,依次出现的,它们都是对MV ...
- 来更新一篇blog吧
最近做了一下hackerrank的20/20的比赛.平时都只能过2题,这周顺利地通过了四道题目竟然.当妄图冲击衬衫的时候,发现剩下三个题一点招数都没有,之后就跑去看了一下node.js了... 这次比 ...
- 层层递进Struts1(八)之总结
先来看一下Struts1学习总结的思维导图,画的主要是Struts1中的重点和博客分布,如下所示: 系列博客的侧重点是: Struts1是什么? 为什么要使用它? 如何使用Struts1? Strut ...
- java小数点的两种处理方法
1. java.text.DecimalFormat; //此方法为四舍五入 例如:DecimalFormat df = new DecimalFormat("#.0" ...
- Servlet 第六课: Session的使用
课程目标: 通过这节课,我们能够学会加入session,学会调用session,以及大概懂得session存在的情况. 课程具体: 1.Session仅仅是存在于浏览器.比方我们打开浏览器获得我们所须 ...
- 基于XMPP实现的Openfire的配置安装+Android客户端的实现[转]
最近在整理一些这方面的资料,闲话少说,咱还是直奔主题吧 :) http://blog.csdn.net/sk719887916/article/details/40541163 https://git ...
- VMware安装CentOS后网络设置
在使用CentOS虚拟机后,出现了无法上网的情况,使用主机ping虚机地址可以ping通,而虚机ping不通主机,同时虚机也无法ping通其他的网址或ip,显示内容为Network is unreac ...
- Extending Robolectric
Robolectric is a work in progress, and we welcome contributions from the community. We encourage dev ...
- Ant学习笔记(1) 基础知识
Ant Apache Ant 是一个基于 Java的构建工具. 下载Ant google.baidu.Windows用户下载zip格式.解压即可. Windows安装Ant Ant本质上是一个Java ...