首页 > 编程语言 >使用PHP连接、操纵Memcached的原理和教程

使用PHP连接、操纵Memcached的原理和教程

时间:2023-02-07 14:31:07浏览次数:55  
标签:教程 缓存 数据库 demos result mysql PHP Memcached


Memcahced开源分布式内存对象缓存系统通过减少数据库的负担,从而能够加速你的web应用。在本文中我将解释怎样实现一个基于Memcahced的缓存系统。

数据库

实例中使用的数据库表包含一个自增的id,一个标题和一个链接字段:



CREATE TABLE demos
(
id INT PRIMARY KEY AUTO_INCREMENT ,
title VARCHAR ( 300 ) ,
link VARCHAR ( 300 ) ,
) ;




第一次用户请求到达

第一次用户发送请求,PHP程序会在访问db数据库的同时,将访问的数据写入Memcached系统。

使用PHP连接、操纵Memcached的原理和教程_缓存

如图所示,user发送了req请求,application发送数据请求到database,database在将数据返回给application的同时,将数据缓存到了Memcached服务器。

第二次用户请求到达了

第二次用户请求到达,会直接读取Memcached服务器的缓存,而不是数据库中的内容,从而减轻了服务器的负担。

使用PHP连接、操纵Memcached的原理和教程_缓存_02

本图显示,第二次的请求,application直接从Memcached(简称Mc)读取数据。

Memcached的安装方法

网络上有大量关于Memcached安装的方法,其实它就是一个缓存服务器应用程序,意思就像是你装了个Mysql一样,装好了用账号密码IP地址连一下就能使用。

以下是一些很好的资源:

php_memcache.dll

​在windows上安装Memcached的方法​

​在Windows7的Xampp上安装Memcached的方法​

​在Windows7上的PHP5.3安装Memcached的方法​

index.php用PHP操作Memcached的演示

 

<?php
include ( 'db.php' ) ;
$memcache = new Memcache ;
$memcache -> connect ( 'localhost' , 11211 ) or die ( "Could not connect" ) ;

//缓存服务器中,都是键值对,这里我们设定唯一的键
$key = md5 ( 'www.crazyant.net' ) ;
$cache_result = array ( ) ;
//根据键,从缓存服务器中获取它的值
$cache_result = $memcache -> get ( $key ) ;

//如果存在该键对应的值,说明缓存中存在该内容
if ( $cache_result ) {
//那我们直接取出缓存的内容就可以了
$demos_result = $cache_result ;
} else {
//如果缓存中没有该键对应的值数据,说明请求是第一次到达

//首先,我们需要从数据库中取出该值
$v = mysql_query ( "select * from demos order by id desc" ) ;
while ( $row = mysql_fetch_array ( $v ) ) {
//取出的内容就是我们需要的
$demos_result [ ] = $row ;
}
//最后,将这次从数据库取出的内容,放到Memcached缓存服务器,这里就是缓存的精髓
$memcache -> set ( $key , $demos_result , MEMCACHE_COMPRESSED , 1200 ) ;
}

//前面的所有操作,最终返回了我们需要的数据
// foreach($demos_result as $row){
echo '<a href=' . $row [ 'link' ] . '>' . $row [ 'title' ] . '</a>' ;
}

?>

 

db.php用于连接数据库的代码

你需要改变代码中的IP地址、用户名、密码、数据库名字。


<?php
$mysql_hostname = "localhost" ;
$mysql_user = "username" ;
$mysql_password = "password" ;
$mysql_database = "database" ;
$bd = mysql_connect ( $mysql_hostname , $mysql_user , $mysql_password )
or die ( "Opps some thing went wrong" ) ;
mysql_select_db ( $mysql_database , $bd ) or die ( "Opps some thing went wrong" ) ;
?>


 

注:本文参考​​Memcached with PHP​

标签:教程,缓存,数据库,demos,result,mysql,PHP,Memcached
From: https://blog.51cto.com/peishuai/6042104

相关文章

  • PHPMyWind支持PDF粘贴
    ​ 项目需求可发布文章需求涉及到富文本编辑器经过查阅我选择了较为简便不需要后端支持可独立完成的tinymce框架官方文档也是相当完整虽然都是全英文但是有强大的......
  • PHP远程操纵WordPress的方法(流程剖析)
    一直想写一个给wordpress群发文章的应用,这样我就能自动采集文章,然后写个脚本自动发送文章了,哈哈。虽然用python干这种事情貌似更加擅长,但是我想做个web界面访问该应用,而pyth......
  • 国外10个非常有趣的PHP博客
    ​​DavidWalshblog​​​​​​DavidWalsh是一个非常有经验的PHP开发者,他参与了很多大型的项目。在他的博客中你能发现几乎每天的对PHP开发的建议。​​Roshan’sblog......
  • PHP数组使用、特性、函数的总结
    包含其他数组的数组成为多维数组关联数组(即非数字索引数组)使用更有意义的数据作为数组的索引1、数组索引数组$products = array(‘a’, ‘b’, ‘c’);//就像一个......
  • 新浪微博的mid转换成base62格式的PHP函数
    最近有用到将新浪微博的mid地址转换成短格式编码的方法,例如:221110410216147026转换后:zF4mOFpN7A比如新浪微博地址可以组装成这样:​​http://weibo.com/1642634100/5en0UftjV......
  • PHP的验证码实现(w3schools推荐)
    本文使用PHP一些可用的特性实现了验证码功能。该教程非常的简单,使用可以改变的字体生成了验证码图片,正如我们所了解的,验证码是用于避免垃圾评论或者自动提交的。本验证码程......
  • PHP中文乱码解决
    网上转载的,但是代码不完全,补充了下,再发通过把Content-Type设置为application/octet-stream,可以把动态生成的内容当作文件来下载,相信这个大家都会。那么用Content-Disp......
  • PHP安全笔记
    1、          MagicQuotes选项PHP.INI中中有三个以magic_quotes_开头的选项magic_quotes_gpc如果是On的话,就会自动用‘\’转义从GET,POST,COOKIE来的数据,这是为......
  • 17个非常有用的PHP类和库
    本文转自互联网。在我们日常程序开发当中,使用一个好的而且成熟的PHP类,可以减少很多手工编码,通过这些通用API的使用,可以大大减轻我们的开发工作。今天,我们将重点介绍了一些很......
  • PHP字符串函数、知识要点总结
    主要包括以下方面:字符串的格式化字符串的连接与分割字符串的比较使用字符串函数匹配和替换子字符串使用正则表达式(下一篇文章专门总结)1、字符串的格式化:chop(rtrim)、ltrim......