>php教程 >php手册 >PHP连接、操纵Memcached的原理和教程

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

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-06-13 09:08:261132검색

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

Memcahced是一个开源分布式内存对象缓存系统。稍微大一点的项目经常会使用 Memcached 以减少数据库的负担,从而加速web应用的响应速度。网络上有大量关于 Memcached 安装的方法以及使用介绍,本文所要说的就是其实 memcached 很简单,没有想象的那么神秘,我们可以简单的理解为它就是一个缓存服务器应用程序,就像是你装了个 Mysql 一样,装好了之后用账号密码IP地址连一下就能使用。

首页简单的介绍一下 memcached 的原理

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

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

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

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

下面通过一个实例分享一下 memcached  的基本使用方法(类似友情链接的一个开发实例)。相信通过这个实例,你就能很清楚的理解了这个东东。

下面的案例假设你已经安装好了 memcached 服务,如果没有安装的话,请参考本站:

memcached是什么?memcache该何使用?

windows系统下安装memcache

(1)新建一个数据库

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

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

(2)程序部分(程序的注释会让你很轻松的理解 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

<?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");
?>

您可能感兴趣的文章

  • PHP连接access数据库的二种方法
  • 如何通过命令行查看memcache当前运行的状态
  • PHP实现同服务器多个二级域名共享 SESSION 数据
  • windows下memcache的安装与配置教程
  • 给php初学者推荐的一本php经典教程书籍
  • php获取目录所有文件并将结果保存到数组的程序
  • php获取汉字拼音首字母的函数(真正可以使用的)
  • 兄弟连php高级编程视频教程下载
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.