Memcached Client的释疑

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  下载:https://github.com/php-memcached-dev/php-memcached/
2.memcache是原生实现的,支持OO和非OO两套接口并存。而memcached是使用libmemcached,只支持OO接口。
3.memcached还有个非常称赞的地方,就是flag不是在操作的时候设置了,而是有了一个统一的setOption()。Memcached实现了更多的memcached协议。
4.memcached支持Binary Protocol,而memcache不支持。这意味着memcached会有更高的性能。不过memcached目前还不支持长连接。

不过可以在window下用memcache,linux下用memcached,只要保证他们使用的接口一致就可以了:

Memcached/Memcache::add — 向一个新的key下面增加一个元素
Memcached/Memcache::addServer — 向服务器池中增加一个服务器
Memcached/Memcache::decrement — 减小数值元素的值
Memcached/Memcache::delete — 删除一个元素
Memcached/Memcache::flush — 作废缓存中的所有元素
Memcached/Memcache::get — 检索一个元素
Memcached/Memcache::getStats — 获取服务器池的统计信息
Memcached/Memcache::getVersion — 获取服务器池中所有服务器的版本信息
Memcached/Memcache::increment — 增加数值元素的值
Memcached/Memcache::replace — 替换已存在key下的元素
Memcached/Memcache::set — 存储一个元素

一. 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端

测试代码:

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.?>  
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中缓存示例

<?php
$sql = ‘SELECT * FROM users‘;
$mc = new Memcache;
$mc->pconnect(‘127.0.0.1‘, 11211);
$key = md5($sql);   //memcached 对象标识符
if ( !($datas = $mc->get($key)) ) {
    //   在 memcached 中未获取到缓存数据,则使用数据库查询获取记录集。
    echo "n".str_pad(‘Read datas from MySQL.‘, 60, ‘_‘)."n";
    $conn = mysql_connect(‘localhost‘, ‘test‘, ‘test‘);
    mysql_select_db(‘test‘);
    $result = mysql_query($sql);
     while ($row = mysql_fetch_object($result))
        $datas[] = $row;
    //   将数据库中获取到的结果集数据保存到 memcached 中,以供下次访问时使用。
    $mc->add($key, $datas);
} else {
     echo "n".str_pad(‘Read datas from memcached.‘, 60, ‘_‘)."n";
}
var_dump($datas);
?>

四.安装OCS客户端(linux)

安装MEMCACHED前需要确认是否有zlib-devel包没有需要执行

yum install zlib-devel

请先检测下是否有已安装了memcached客户端包【包含源码包】如有则不需要安装,但需要重新编译增加-enable-memcached-sasl这个扩展

wget http://pecl.php.net/get/memcached-2.1.0.tgz

tar zxvf memcached-2.1.0.tgz

cd memcached-2.1.0

phpize(如果系统中有两套PHP环境,需绝对路径调用该命令/usr/bin/phpize,该路径为使用OCS的PHP环境路径)

./configure --with-libmemcached-dir=/usr/local/libmemcached --enable-memcached-sasl --with-php-config=(这后面是php-config文件绝对路径)(注意这个参数)

make

make install

最后修改php.ini文件(locate找该文件,如果系统中有两套PHP环境,需找到使用OCS的PHP环境路径,对应修改之),增加extension=memcached.so

memcached.use_sasl = 1

五.解决OCS的密码问题(linux)

OCS使用时必须输入用户名密码的这个比较烦,小弟我又弄了一个patch,解决那个SASL配置的问题,分享给大家试试。应该能解决C++/C Python PHP 等依赖libmemcached作为客户端的Application,不保证能解决所有环境下的问题哈。

下载在此: https://github.com/ychtiger/libmemcached-OCS

配置:

ALIYUN_OCS_ENABLE 用来标识是否开启OCS功能,如果访问OCS服务,需要设置为true 
ALIYUN_OCS_NAME OCS服务用户名 
ALIYUN_OCS_PASW OCS服务密码 
注意,环境变量一定要设置在你程序启动的用户下,建议直接在.bashrc中设置

主要下面的代码就可以运行了(注释了鉴权函数)

<?php
$memc = new Memcached();
$memc->setOption(Memcached::OPT_COMPRESSION, false);
$memc->setOption(Memcached::OPT_BINARY_PROTOCOL, true);
$memc->addServer("10.232.X.X", 11211);
//$memc->setSaslAuthData("username", "password");//鉴权函数可以取消了
while(1)
{
  $memc->set("key", "get OCS value");
  $result = $memc->get("key");
  var_dump($result);
  sleep(1);
}
?>

时间: 2024-10-14 09:24:48

Memcached Client的释疑的相关文章

安装java memcached client到maven repository

由于目前java memcached client没有官方的maven repository可供使用,因此使用时需要手动将其安装到本地repository.java memcached client的jar包下载地址:https://github.com/gwhalin/Memcached-Java-Client/downloads 目前2.6.2版本的java memcached client要依赖slf4j-simple.slf4j-api.commons-pool三个包,依此我们可以为其编

java memcached client

Memcach什么是Memcache Memcache集群环境下缓存解决方案 Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像.视频.文件以及数据库检索的结果等.简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度. Memcache是danga的一个项目,最早是LiveJournal 服务的,最初为了加速 LiveJournal 访问速度而开发的,后来被很多大型的网站采用. Memcac

MemCached Client集群方案

MemCached Client集群方案 By mingjun Hou Cluster的实现 Memcached作为集中式Cache,就存在着集中式的致命问题:单点问题,Memcached支持多Instance分布在多台机器上,仅仅 只是解决了数据全部丢失的问题,但是当其中一 台机 器出错以后,还是会导致部分数据的丢失,一个篮子掉在地上还是会把部分的鸡蛋打破.因此就需要实现一个备份机制,能够保证Memcached在部分失效以后,数据还能够 依然使用,因 此做Cluster也是必要的. (1)  

enyim.com Memcached Client:memcached实例

在上一篇文章,我们讲了,为什么要使用memched做为缓存服务器(没看的同学请点这里).下面让我们以memcached-1.2.1-win32版本的服务组件(安装后是以一个windows服务做daemon)和C#API(Enyim.Caching)为基础,做一个"Hello world"级的程序,让我们真正感受到memcached就在我们身边.后一的文章,我们还讲memcached的核心部分(根据key来hash存取数据,缓存数据在server端的内存存储结构)和一些好的案例. 下面的

memcached client --ref

Clients Client API's / libraries Updated Jul 14, 2012 by [email protected] ref:https://code.google.com/p/memcached/wiki/Clients C / C++ libmemcached http://libmemcached.org/ by Brian Aker, Commercial Support available from Data Differential BSD licen

Memcached通用类(基于enyim.com Memcached Client)

一.如果用官方提供的方法,在web.config里面配置好了各个参数和服务器IP.如下图: <?xml version="1.0"?> <configuration> <configSections> <sectionGroup name="enyim.com"> <section name="memcached" type="Enyim.Caching.Configuration.

Memcached Java Client API详解

针对Memcached官方网站提供的java_memcached-release_2.0.1版本进行阅读分析,Memcached Java客户端lib库主要提供的调用类是SockIOPool和MemCachedClient?,关键类及方法整理说明如下. SockIOPool 这个类用来创建管理客户端和服务器通讯连接池,客户端主要的工作包括数据通讯.服务器定位.hash码生成等都是由这个类完成的. public static SockIOPool getInstance() 获得连接池的单态方法.

memcached java client 3.0.2详解

memcached-java-client-3.0.2详解 一:MemCachedClient的创建 创建该客户端对象的构造方法有以下几个: 1, /** * Creates a new instance of MemCachedClient. */ public MemCachedClient() { this(null, true, false); } 2, /** * Creates a new instance of MemCachedClient accepting a passed

Memcached Java Client with sample program--reference

In my previous post, I listed down most common telnet commands for memcached with sample execution terminal logs. Today I want to discuss about the Memcached Client program available in Java language. There are three most widely used memcached client