使用PHP创建Memcached数据库客户端

数据库 其他数据库 数据库运维
本文将为大家解释的是PHP环境下如何操作Memcached数据库的相关数据,这也是Web高性能开发的一部分。

Memcached 是一个键值存储系统,它将关键数据存储在内存中,大大减少存取数据的时间。使用Memcached的好处不言而喻,它不仅减少了系统访问数据库的压力,而且提高系统的反应速度。至于什么样的系统需要使用memcache,笔者建议数据量大,访问频繁系统可以采取Memcached作为缓存的中间层。

使用Memcached的缺点除了增加程序的代码量,还有就是不能保证数据库的实时性,另外在第一次初始化数据库会需要额外的时间。但是这些的缺点比起它的优点是很微不足道。

PHP带有操作Memcached的扩展,它提供一组函数来操作Memcached服务器,将他们简单分一下类:

1。Memcached的连接函数(connect, pconnect)

2。memcahced的操作函数(set, get, delete, replace, flush)

3。多服务器配置函数(addServer)

4。状态监控函数(getStats.....)

下面摘一段代码,给大家一个直观的印象:(假设Memcached安装在172.10.10.10上面,端口号12121)

 

  1. $memcache = new Memcached();  
  2. $memcahce->connect('172.10.10.10', 12121);  
  3. $memcache->set('Key''Value');  
  4. $memcache->get('Key'); 

 

上面的主要完成了Memcached的简单操作流程:连接Memcached服务器,设置值,取值('Key'的值是'Value');

这里需要向大家说明一下addServer函数和connect函数,addServer是将多个服务器放在连接池,而connect只是将连接某一台服务器;如果在使用了addServer,再使用connect,这里就会只使用一台服务器。

介绍了Memcached的使用后,下面向大家介绍如何编写自己的PHP Memcached的客户端

Memcached是一个服务器端程序,我们自然可以使用PHP中的套接字程序来连接,并进行相应的通讯,完成数据的存储操作。要使用PHP和Memcached通讯,首先需要知道Memcached的通讯协议,相关的信息可以在Memcached的源码的doc/protocol.txt中找到。

这里笔者使用get命令向大家展示一下这个过程

这个命令主要是从数据中提取数据,输入格式: get key\r\n

如果服务器没有这个值,则返回: END\r\n

如果这个值存在,返回: VALUE key <标记> <数据长度> \r\n 数据块\r\n

以下代码是简单模拟的客户端操作

 

  1. $fp = fsocketopen('172.10.10.10', 12121, $errorno$errstr, 1);  
  2. if(!$fp)  
  3.   echo "$errstr";  
  4. else 
  5. {  
  6.   $out = "get key \r\n";  
  7.   fwrite($out);  
  8.   while(!feof($fp))  
  9.     $str  . = fgets($fp);  
  10.   if(stripos($str'END') ===0)  
  11.     exit("NO value find")  
  12.   $arr = implode('\r\n'$str);  
  13.   echo $arr[1];  

 

简单解释上面的代码,使用fsocketopen打开服务器的socket通讯接口,然后向其发送get key命令, 然后获取返回的数据,并解析返回的数据。这里都没有做异常的处理,在编程的时候要填上。

[[12830]]

延伸阅读

Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信。但是它并不提供冗余(例如,复制其hashmap条目);当某个服务器S停止运行或崩溃了,所有存放在S上的键/值对都将丢失。

Memcached由Danga Interactive开发,用于提升LiveJournal.com访问速度的。LJ每秒动态页面访问量几千次,用户700万。Memcached将数据库负载大幅度降低,更好的分配资源,更快速访问。

原文标题:使用php操作memcached

链接:http://www.cnblogs.com/kucongzhi/archive/2010/07/11/1775275.html

【编辑推荐】

  1. 专题:MySQL从入门到精通教程
  2. MySQL在太阳下茁壮 在开源中强大
  3. 分布式缓存系统memcached简介与实践
  4. 从memcached看MySQL和关系数据库的未来
责任编辑:彭凡 来源: 博客园
相关推荐

2009-11-25 13:21:30

PHP作为memcac

2011-09-27 10:05:57

DBeaver数据库

2013-06-05 09:38:22

HeidiSQL

2022-05-16 07:37:58

SQL 编辑器数据库管理工具

2011-06-28 09:09:57

JavaMemcached

2010-08-18 09:52:25

Memcache

2011-08-17 10:10:59

2020-03-19 08:00:00

客户端KubernetesAPI

2010-03-19 13:05:11

Perst Lite

2012-10-11 17:02:02

IBMdw

2010-05-12 15:46:51

Subversion客

2014-01-07 14:39:26

Android开发RxJavaREST

2011-04-06 14:24:20

Nagios监控Linux

2011-03-21 14:53:36

Nagios监控Linux

2011-05-24 16:47:20

数据存储

2020-12-28 09:36:53

MySQL数据库工具

2011-11-30 14:21:19

Java分布式缓存

2012-01-13 10:29:37

ibmdw

2011-04-06 14:24:27

Nagios监控Linux

2010-06-01 13:54:42

TortoiseSVN
点赞
收藏

51CTO技术栈公众号