开发者社区> 航空母舰> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

PHP MemCached win安装

简介:
+关注继续查看

1.目前大多数php环境里使用的都是不带d的memcache版本,这个版本出的比较早,是一个原生版本,完全在php框架内开发的。与之对应的带d的memcached是建立在libmemcached的基础上,所以相对来说,memcached版本的功能更全一些,目前只有Linux版本 。
memcache:http://cn2.php.net/manual/en/book.memcache.php
memcached:http://cn2.php.net/manual/en/book.memcached.php
2.Memcache是原生实现的,支持OO和非OO两套接口并存。而memcached是使用libmemcached,只支持OO接口。
3.memcached还有个非常称赞的地方,就是flag不是在操作的时候设置了,而是有了一个统一的setOption()。Memcached实现了更多的memcached协议。
4.memcached支持Binary Protocol,而memcache不支持。这意味着memcached会有更高的性能。不过memcached目前还不支持长连接。

 

memcached是一个高性能的分布式的内存对象缓存系统,它能够用来存储各种

格式的数据,包括图像、视频、文件以及数据库检索的结果等


  
使用 Memcache d的网站一般流量都是比较大的,为了缓解数据库的压力,让 Memcache d作为一个缓存区域,把部分信息保存在内存中,在前端能

 

够迅速的进行存取。

一  Memcached服务器端的安装 (此处将其作为系统服务安装)
win32 binary: memcached-win32-bin.zip下载地址:http://code.jellycan.com/memcached/

1 解压缩文件到

Java代码  收藏代码
  1. c:\memcached  

2 命令行输入

Java代码  收藏代码
  1. C:\memcached\memcached.exe -d install  

NOTE: 以后memcached将作为windows的一个服务每次开机时自动启动。这样服务器端已经安装完毕了。
3 命令行输入

Java代码  收藏代码
  1. C:\memcached\memcached.exe -d start  

该命令启动 Memcached ,默认监听端口为 11211,通过 memcached.exe -h 可以查看其帮助

 

命令行下测试

4、 telnet 127.0.0.1 11211   (使用telnet连接测试是否成功)

5、 输入:stats 命令查看基本信息, 然后在命令行中输入netstat -n -a 可以查看端口  

 

memcache服务器安全:

Memcache服务器端都是直接通过客户端连接后直接操作,没有任何的验证过程,这样如果服务器是直接暴露在互联网上的话是比较危险,轻则数据泄 露被其他无关人员查看,重则服务器被入侵,况且里面可能存在一些我们未知的bug或者是缓冲区溢出的情况,这些都是我们未知的,所以危险性是可以预见的。 为了安全起见,做两点建议,能够稍微的防止黑客的入侵或者数据的泄露。

现在就关于修改memcache服务器配置的问题说明如下:

1>用内网ip的方式提供web应用服务器调用,不允许直接通过外网调用,如将memcache服务器放在192.168.1.55的服务器上

2>修改端口,如改为11200

3>分配内存,如分配1024M(1G内存)

方法如下:

 

1>开始>运行:CMD(确定)

2>cd C:\memcached(回车)

3>memcached -m 1024 -p 11200 -l 192.168.1.55(回车)

注意,此时命令行不会回到C:\memcached>状态,并且实际上memcache服务器悄悄变为stop状态了。此窗口不可以关闭。新开一个cmd窗口

4>开始>运行:CMD(确定)

5>cd C:\memcached(回车)

6>memcached -d start(回车)可以关闭此cmd窗口。

此时可以使用新配置的memcache服务器了。

 

上述方法虽然解决了修改默认配置的问题,但是始终会有一个cmd窗口不可以关闭,否则就回到11211端口的默认配置。

更好的解决方案是通过修改服务的注册表配置:

1>开始>运行:regedit(回车)

2>在注册表中找到:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server

3>默认的ImagePath键的值是:"c:\memcached\memcached.exe" -d runservice,改为:"c:\memcached\memcached.exe" -d runservice -m 512 -p  11200 -l 192.168.1.55(确定,关闭注册表)

4>我的电脑(右键)>管理>服务 找到memcache的服务,重新启动一次即可生效。

此时,同网段内的电脑仍然可以利用这台memcache服务器,我们限定指定的web应用服务器才能够使用,通过防火墙的方式。如只允许 192.168.1.2这台Web服务器对Memcache服务器的访问,能够有效的阻止一些非法访问,相应的也可以增加一些其他的规则来加强安全性,这 个可以根据自己的需要来做。

 

二PHP中配置 Memcachd Client端

这里我们为了连接memcached server 我们需要php_memcache.dll

PHP membercached 扩展下载地址:http://downloads.php.net/pierre/

方法1  

1、下载: php_memcache.dll 组件 (WAMP自带了) 请自己查找对应的php版本的文件

2、复制 php_memcache.dll 到指定的组件目录, 默认在 php\ext\

3、在PHP.ini 加入一句话: extension=php_memcache.dll  

4、重启WEB服务,使用 phpinfo() 函数查看启用情况 如果有memcache,那么就说明安装成功! 

php测试

Java代码  收藏代码
  1. <?php  
  2. $memcache = new Memcache();  //windows  
  3. $memcache->connect('127.0.0.1'11211 ) or die ( "Could not connect Memcached server!" );    
  4. $memcache->set( 'Memcache'"hello Memcache!<br/>");  
  5. echo $memcache->get('Memcache');  
  6. ?>  

结果hello Memcache!

恭喜你,配置成功了,现在开始慢慢捣鼓吧!不能运行看配置是否成功,或者检查下端口是否开放

Java代码  收藏代码
  1. <?php  
  2. $memcache = new Memcached();  //linux  
  3. $memcache->addServer('127.0.0.1'11211 ) or die ( "Could not connect Memcached server!" );    
  4. $memcache->set( 'Memcached'"hello Memcached!<br/>");  
  5. echo $memcache->get('Memcached');  
  6. ?>  

方法二

可以避开扩展、重新编译所带来的麻烦,那就是直接使用 php-memcached-client。

本文选用第二种方式,虽然效率会比扩展库稍差一些 ,但问题不大。
首先 下载 memcached-client.php,在下载了 memcached-client.php 之后,就可以通过这个文件中的类“memcached”对 memcached 服务进行操作了。其实代码调用非常简单,主要会用到的方法有 add()、get()、replace() 和 delete(),方法说明如下:
add ($key, $val, $exp = 0)
往 memcached 中写入对象,$key 是对象的唯一标识符,$val 是写入的对象数据,$exp 为过期时间,单位为秒,默认为不限时间;
get ($key)
从 memcached 中获取对象数据,通过对象的唯一标识符 $key 获取;
replace ($key, $value, $exp=0)
使用 $value 替换 memcached 中标识符为 $key 的对象内容,参数与 add() 方法一样,只有 $key 对象存在的情况下才会起作用;
delete ($key, $time = 0)
删除 memcached 中标识符为 $key 的对象,$time 为可选参数,表示删除之前需要等待多长时间。
下面是一段简单的测试代码,代码中对标识符为 'mykey' 的对象数据进行存取操作:

Java代码  收藏代码
  1. <?php  
  2. //   包含 memcached 类文件  
  3. require_once('memcached-client.php');  
  4. //   选项设置  
  5. $options = array(  
  6.     'servers' => array('192.168.1.1:11211'), //memcached 服务的地址、端口,可用多个数组元素表示多个 memcached 服务  
  7.     'debug' => true,  //是否打开 debug  
  8.     'compress_threshold' => 10240,  //超过多少字节的数据时进行压缩  
  9.     'persistant' => false  //是否使用持久连接  
  10.     );  
  11. //   创建 memcached 对象实例  
  12. $mc = new memcached($options);  
  13. //   设置此脚本使用的唯一标识符  
  14. $key = 'mykey';  
  15. //   往 memcached 中写入对象  
  16. $mc->add($key, 'some random strings');  
  17. $val = $mc->get($key);  
  18. echo "n".str_pad('$mc->add() '60'_')."n";  
  19. var_dump($val);  
  20. //   替换已写入的对象数据值  
  21. $mc->replace($key, array('some'=>'haha''array'=>'xxx'));  
  22. $val = $mc->get($key);  
  23. echo "n".str_pad('$mc->replace() '60'_')."n";  
  24. var_dump($val);  
  25. //   删除 memcached 中的对象  
  26. $mc->delete($key);  
  27. $val = $mc->get($key);  
  28. echo "n".str_pad('$mc->delete() '60'_')."n";  
  29. var_dump($val);  
  30. ?>  

 是不是很简单,在实际应用中,通常会把数据库查询的结果集保存到 memcached 中,下次访问时直接从 memcached 中获取,而不再做数据库查询操作,这样可以在很大程度上减轻数据库的负担。通常会将 SQL 语句 md5() 之后的值作为唯一标识符 key 。下边是一个利用 memcached 来缓存数据库查询结果集的示例(此代码片段紧接上边的示例代码):

Java代码  收藏代码
  1. <?php  
  2. $sql = 'SELECT * FROM users';  
  3. $mc = new Memcache;   
  4. $mc->pconnect('127.0.0.1'11211);    
  5. $key = md5($sql);   //memcached 对象标识符  
  6. if ( !($datas = $mc->get($key)) ) {  
  7.     //   在 memcached 中未获取到缓存数据,则使用数据库查询获取记录集。  
  8.     echo "n".str_pad('Read datas from MySQL.'60'_')."n";  
  9.     $conn = mysql_connect('localhost''test''test');  
  10.     mysql_select_db('test');  
  11.     $result = mysql_query($sql);  
  12.      while ($row = mysql_fetch_object($result))  
  13.         $datas[] = $row;  
  14.     //   将数据库中获取到的结果集数据保存到 memcached 中,以供下次访问时使用。  
  15.     $mc->add($key, $datas);  
  16. else {  
  17.      echo "n".str_pad('Read datas from memcached.'60'_')."n";  
  18. }  
  19. var_dump($datas);  
  20. ?>  

 可以看出,使用 memcached 之后,可以减少数据库连接、查询操作,数据库负载下来了,脚本的运行速度也提高了。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
如何修复“PHP 安装缺少 WordPress 所需的 MySQL 扩展”的错误?
在WordPress建站,WordPress定制开发过程中,开发者容易遇见“您的 PHP 安装似乎缺少 WordPress 所需的 MySQL 扩展”的错误提示,如果出现这样的情况,应该怎么办?北京六翼信息有限公司的开发工程师指出,要修复错误“您的 PHP 安装似乎缺少 WordPress 所需的 MySQL 扩展”,您需要确保您的 PHP 安装已正确安装和配置 MySQL 数据库驱动程序 (mysqlnd) 和 mysqli 扩展。只有这样,您才能恢复 WordPress 和 WordPress 数据库之间的正常连接,并让您的网站重新运行。
0 0
ECS配置mySQL\MariaDB和PHP环境
ECS配置mySQL\MariaDB和PHP环境
0 0
php操作mysql防止sql注入(合集)
php操作mysql防止sql注入(合集)
0 0
Centos中查看nginx、apache、php、mysql配置文件路径
Centos中查看nginx、apache、php、mysql配置文件路径
0 0
MySQL事务的四种隔离类型以及PHP框架Yii2中的源码解读和实际应用
MySQL事务的四种隔离类型以及PHP框架Yii2中的源码解读和实际应用
0 0
头歌php mysql操作答案
头歌php mysql操作答案
0 0
PHP连接MySQL 8.0报错的解决办法
PHP连接MySQL 8.0报错的解决办法
0 0
PHP连接MySQL 8.0报错的解决办法
PHP连接MySQL 8.0报错的解决办法
0 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
CentOS Nginx PHP JAVA多语言镜像使用手册
立即下载
CentOS Nginx PHP JAVA 多语言镜像使用手
立即下载
PHP运行机制初探
立即下载