感谢支持
我们一直在努力

Ubuntu 10.10下编译安装Memcached 1.4.5

一、简介


Memcached是国外社区网站 LiveJournal 的开发团队开发的高性能的分布式内存缓存服务器。一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、提高可扩展性。


官方网站:http://www.danga.com/memcached/


二、原理


libevent是一套跨平台的事件处理接口的封装,能够兼容包括这些操作系统:Windows/Linux/BSD/Solaris 等操作系统的的事件处理。Memcached 使用libevent来进行网络并发连接的处理,能够保持在很大并发情况下,仍旧能够保持快速的响应能力。


1、数据存储方式:Slab Allocation


Slab Allocator的基本原理是按照预先规定的大小,将分配的内存分割成特定长度的块,以完全解决内存碎片问题。


Slab Allocation的原理相当简单。将分配的内存分割成各种尺寸的块(chunk),并把尺寸相同的块分成组(chunk的集合)


缺点:由于分配的是特定长度的内存,因此无法有效利用分配的内存。


2、数据过期方式:Lazy Expiration


memcached内部不会监视记录是否过期,而是在get时查看记录的时间戳,检查记录是否过期。


LRU——Least Recently Used,当memcached的内存空间不足时(无法从slab class 获取到新的空间时),就从最近未被使用的记录中搜索,并将其空间分配给新的记录。


三、安装


Memcache包括服务器和客户端的安装。可以在各种linux平台上安装,也可以在windows上安装。


服务器端


    libevent
       官网:http://monkey.org/~provos/libevent/
       下载:http://monkey.org/~provos/libevent-1.4.9-stable.tar.gz
    Memcached
       官网:http://www.danga.com/memcached
       下载:http://www.danga.com/memcached/dist/


libevent安装


>tar -zxvf libevent-1.4.9-stable.tar.gz
>cd libevent-1.4.9-stable
>./configure      //默认装到/usr/lib/下
>make
>make install


但是默认情况下,libevent是安装到了/usr/local/lib目录下,而memcached找ibevent-2.0.so.5模块的路径


却是/usr/lib目录,可想而知,肯定找不到的啊,因此需要你软链接过去,或者你指定安装目录也行。


ln -s  /usr/local/lib/libevent-2.0.so.5    /usr/lib/libevent-2.0.so.5


好了,到此为止,才算只真正的安装好了libevent.



     Memcached安装


>tar -zxvf memcached-1.4.1.tar.gz
>cd memcached-1.4.1
>./configure –prefix=/usr/local/memcached
>make
>make install
    Memcached启动


>./memcached -d -m 10 -u root -l 10.20.20.194 -p 11210 -c 256 -P /tmp/memcached.pid


参数解释:
   -d 以守护程序(daemon)方式运行 memcached。


   -u 指定用户,如果当前为 root 的话,需要使用此参数指定用户。
   -m 设置 memcached 可以使用的内存大小,单位为Mb,缺省是 64 MB;
   -l 设置监听的 IP 地址,如果是本机的话,通常可以不设置此参数;
   -p 设置监听的端口,默认为 11211,所以也可以不设置此参数;(此处不设置,测试后发现无法连接)


   -c 设置最大运行的并发连接数,默认是1024


   -P 设置保存Memcache的pid文件


 


   Memcached停止


>kill `cat /tmp/memcached.pid`


备注:


   cat /tmp/memcached.pid——查看memcached的进程号


 


   查看Memcached帮助信息


>./memcached -h


 


   检查Memcached是否运行正常


>ps auxxww | grep memcached


 


  客户端


   a、linux安装


         Memcached有两种安装方式:一种是直接安装memcache;一种是安装memcached。


      (1)、安装memcache


       PHP Memcache扩展


          官网:http://pecl.php.net/package/memcache
          下载:http://pecl.php.net/get/memcache-3.0.4.tgz


       安装


>tar -zxvf memcache-3.0.4.tgz
>cd memcache-3.0.4
>/usr/local/php/bin/phpize
>./configure –with-php-config=/usr/local/php/bin/php-config
>make
>make install


        配置


           在php.ini中新增配置内容:
           extension_dir = “/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/”
           extension = memcache.so


 


      (2)、安装memcached


            Memcached客户端是基于libmemcached的,所以需先安装libmemcached。


            libmemcached


               官网:http://download.tangent.org


               下载:http://download.tangent.org/libmemcached-0.33.tar.gz


            安装


>tar -zxvf libmemcached-0.33.tar.gz
>cd libmemcached-0.33
>./configure –prefix=/usr/local/libmemcached/ –with-libmemcached-dir=/usr/local/libmemcached/           –此处–with-libmemcached-dir需验证


>make
>make install


 


            PHP Memcached扩展


               官网:http://pecl.php.net/package/memcached
               下载:http://pecl.php.net/get/memcached-1.0.0.tgz


       安装


 


>tar -zxvf memcached-1.0.0.tgz
>cd memcached-1.0.0
>./configure –with-php-config=/usr/local/php/bin/php-config –with-libmemcached-dir=/usr/local/libmemcached/
>make
>make install
       配置


 


           在php.ini中新增配置内容:
           extension_dir = “/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/”
           extension = memcache.so


 


   b、Windows安装


       1、下载php_memcache.dll


       2、将php_memcache.dll拷贝到php/ext/目录下


       3、修改php.ini,加入extension=php_memcache.dll


       4、重启服务器
       5、检查phpinfo(),会发现memcache的部分


 


四、安装常见问题及解决


    1、现象:./memcached -h出现如下提示
              checking for libevent directory… configure: error: libevent is required.  You can get it from http://www.monkey.org/~provos/libevent/
        解决:在当前目录下,执行
              >whereis libevent
              >LD_DEBUG=libs ./memcached -v 2>&1 > /dev/null | less
              >ln -s /usr/src/libevent-1.4.9-stable/lib/libevent-1.4.so.2 /lib/


     2、现象:运行程序时,页面提示:Warning: Memcache::connect() [memcache.connect]: Can’t connect to 10.20.20.194:11211, 由于连接方在一段时间后没有正确答复或连接的主机没有反应,连接尝试失败。 (10060) in E:\AppServ\www\test\memcache\test1.php on line 4
       解决:设定端口,启动改为-p 11210
              >./memcached -d -m 10 -u root -l 10.20.20.194 -p 11210 -c 256 -P /tmp/memcached.pid


     3、现象:运行时提示:checking for libmemcached location… configure: error: memcached support requires libmemcached. Use –with-libmemcached-dir=<DIR> to specify the prefix where libmemcached headers and library are located


        解决:在当前目录下,执行whereis libmemcached找到libmemcached路径,然后添加选项–with-libmemcached-dir=libmemcached路径.


 


五、应用


<?php
//连接
$mem=new Memcache;
$mem->connect(“10.20.20.194”,11210);


//保存数据
$mem->set(‘key1′,’This is first value’,0,60);
$val=$mem->get(‘key1’);
echo “Get key1 value: “.$val
.”<br>”;


//替换数据
$mem->replace(‘key1′,’This is replace value’,0,60);


$val=$mem->get(‘key1’);
echo “Get key1 value: “.$val.”<br>”;


//保存数组
$arr=array(‘aaa’,’bbb’,’ccc’,’ddd’);
$mem->set(‘key2’,$arr,0,60);
$val2=$mem->get(‘key2’);
echo “Get key2 value: “;
print_r($val2);
echo
“<br>”;


//删除数据
$mem->delete(‘key1’);
$val=$mem->get(‘key1’);
echo “Get key1 value: “.$val.”<br>”;


//清除所有数据
$mem->flush();
$val2=$mem->get(‘key2’);
echo “Get key2 value: “;
print_r($val2);
echo “<br>”;


//关闭连接
$mem->close();
?>



六、Memcache方法说明
    1、Memcache::add — 添加一个值,如果已经存在,则���回false
    2、Memcache::addServer — 添加一个可供使用的服务器地址


       参数:


            第一个参数表示服务器的地址,


            第二个参数表示端口,


            第三个参数表示是否是一个持久连接,


            第四个参数表示这台服务器在所有服务器中所占的权重,


            第五个参数表示连接的持续时间,


            第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,


            第七个参数用来控制服务器的在线状态,


            第八个参数允许设置一个回掉函数来处理错误信息。
    3、Memcache::close — 关闭一个Memcache对象
    4、Memcache::connect — 创建一个Memcache对象
    5、memcache_debug — 控制调试功能,前提是php在编译的时候使用了–enable-debug选项
    6、Memcache::decrement — 对保存的某个key中的值进行减法操作
    7、Memcache::delete — 删除一个key值


       参数:


            第一个参数表示key,


            第二个参数可选,表示删除延迟的时间。
    8、Memcache::flush — 清除所有缓存的数据,但是不会削去使用的内存空间。
    9、Memcache::get — 获取一个key值


       参数:


            一个参数,表示key
   10、Memcache::getExtendedStats — 获取进程池中所有进程的运行系统统计
   11、Memcache::getServerStatus — 获取运行服务器的参数


       参数:


            第一个参数表示服务器的地址,


            第二个参数表示端口
   12、Memcache::getStats — 返回服务器的一些运行统计信息


       参数:


           第一个参数表示要求返回的类型:reset, malloc, maps, cachedump, slabs, items, sizes;
           第二个参数和第三个参数是在第一个参数设置为“cachedump”时使用的。
   13、Memcache::getVersion — 返回运行的Memcache的版本信息
   14、Memcache::increment — 对保存的某个key中的值进行加法操作
   15、Memcache::pconnect — 创建一个Memcache的持久连接对象
   16、Memcache::replace — R对一个已有的key进行覆写操作


       参数:


            第一个参数是key,


            第二个参数是value,


            第三个参数可选,表示是否压缩保存,


            第四个参数可选,用来设置一个过期自动销毁的时间。


   17、Memcache::set — 添加一个值,如果已经存在,则覆写


       参数:


            第一个参数是key,


            第二个参数是value,


            第三个参数可选,表示是否压缩保存,


            第四个参数可选,用来设置一个过期自动销毁的时间。
   18、Memcache::setCompressThreshold — 对大于某一大小的数据进行压缩


       参数:


            第一个参数表示处理数据大小的临界点,


            第二个参数表示压缩的比例,默认为0.2。
   19、Memcache::setServerParams — 在运行时修改服务器的参数


       参数:


            第一个参数表示服务器的地址,


            第二个参数表示端口,


            第三个参数表示连接的持续时间,


            第四个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,


            第五个参数用来控制服务器的在线状态,


            第六个参数允许设置一个回掉函数来处理错误信息。

赞(0) 打赏
转载请注明出处:服务器评测 » Ubuntu 10.10下编译安装Memcached 1.4.5
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏