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

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

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-06-13 09:08:261132Durchsuche

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高级编程视频教程下载
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn