返回列表

转载:Linux下的Memcache安装

默认分类 2014/04/19 00:03

原文地址: Linux下的Memcache安装

《[Windows下的Memcache安装](http://www.ccvita.com/258.html "Windows下的Memcache安装")》

最近在研究怎么让Discuz!去应用Memcache去做一些事情,记录下Memcache安装的过程。

Linux下Memcache服务器端的安装

服务器端主要是安装memcache服务器端,目前的最新版本是 memcached-1.3.0 。

下载:http://www.danga.com/memcached/dist/memcached-1.2.2.tar.gz

另外,Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libevent,libevent的最新版本是libevent-1.3。(如果你的系统已经安装了libevent,可以不用安装)

官网:http://www.monkey.org/~provos/libevent/

下载:http://www.monkey.org/~provos/libevent-1.3.tar.gz

用wget指令直接下载这两个东西.下载回源文件后。

1.先安装libevent。这个东西在配置时需要指定一个安装路径,即./configure --prefix=/usr;然后make;然后make install;

2.再安装memcached,只是需要在配置时需要指定libevent的安装路径即./configure --with-libevent=/usr;然后make;然后make install;

这样就完成了Linux下Memcache服务器端的安装。详细的方法如下:

> 1.分别把memcached和libevent下载回来,放到 /tmp 目录下:
> 
> # cd /tmp
> 
> # wget http://www.danga.com/memcached/dist/memcached-1.2.0.tar.gz
> 
> # wget http://www.monkey.org/~provos/libevent-1.2.tar.gz
> 
> 2.先安装libevent:
> 
> # tar zxvf libevent-1.2.tar.gz
> 
> # cd libevent-1.2
> 
> # ./configure --prefix=/usr
> 
> # make
> 
> # make install
> 
> 3.测试libevent是否安装成功:
> 
> # ls -al /usr/lib | grep libevent
> 
> lrwxrwxrwx    1 root     root          21 11?? 12 17:38 libevent-1.2.so.1 -> libevent-1.2.so.1.0.3
> 
> -rwxr-xr-x       1 root     root          263546 11?? 12 17:38 libevent-1.2.so.1.0.3
> 
> -rw-r--r--        1 root     root          454156 11?? 12 17:38 libevent.a
> 
> -rwxr-xr-x       1 root     root          811 11?? 12 17:38 libevent.la
> 
> lrwxrwxrwx    1 root     root          21 11?? 12 17:38 libevent.so -> libevent-1.2.so.1.0.3
> 
> 还不错,都安装上了。
> 
> 4.安装memcached,同时需要安装中指定libevent的安装位置:
> 
> # cd /tmp
> 
> # tar zxvf memcached-1.2.0.tar.gz
> 
> # cd memcached-1.2.0
> 
> # ./configure --prefix=/usr --with-libevent=/usr
> 
> # make
> 
> # make install
> 
> 如果中间出现报错,请仔细检查错误信息,按照错误信息来配置或者增加相应的库或者路径。
> 
> 安装完成后会把memcached放到 /usr/local/bin/memcached ,
> 
> 5.测试是否成功安装memcached:
> 
> # ls -al /usr/local/bin/mem*
> 
> -rwxr-xr-x    1 root     root       137986 11?? 12 17:39 /usr/local/bin/memcached
> 
> -rwxr-xr-x    1 root     root       140179 11?? 12 17:39 /usr/local/bin/memcached-debug

安装Memcache的PHP扩展

1.在http://pecl.php.net/package/memcache 选择相应想要下载的memcache版本。

2.安装PHP的memcache扩展

> tar vxzf memcache-2.2.1.tgz
> 
> cd memcache-2.2.1
> 
> /usr/local/php/bin/phpize
> 
> ./configure --enable-memcache --with-php-config=/usr/local/php/bin/php-config --with-zlib-dir
> 
> make
> 
> make install

3.上述安装完后会有类似这样的提示:

> Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/

4.把php.ini中的extension_dir = "./"修改为

> extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/"

5.添加一行来载入memcache扩展:extension=memcache.so

memcached的基本设置

1.启动Memcache的服务器端:

# /usr/local/bin/memcached -d -m 10  -u root -l 192.168.0.200 -p 12000 -c 256 -P /tmp/memcached.pid

> -d选项是启动一个守护进程,
> 
> -m是分配给Memcache使用的内存数量,单位是MB,我这里是10MB,
> 
> -u是运行Memcache的用户,我这里是root,
> 
> -l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.0.200,
> 
> -p是设置Memcache监听的端口,我这里设置了12000,最好是1024以上的端口,
> 
> -c选项是最大运行的并发连接数,默认是1024,我这里设置了256,按照你服务器的负载量来设定,
> 
> -P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid,

2.如果要结束Memcache进程,执行:

> # kill `cat /tmp/memcached.pid`

也可以启动多个守护进程,不过端口不能重复。

3.重启apache,service httpd restart

Memcache环境测试

运行下面的php文件,如果有输出This is a test!,就表示环境搭建成功。开始领略Memcache的魅力把!

< ?php

$mem = new Memcache;

$mem->connect("127.0.0.1", 11211);

$mem->set('key', 'This is a test!', 0, 60);

$val = $mem->get('key');

echo $val;

?>

参考资料

对Memcached有疑问的朋友可以参考下列文章:

Linux下的Memcache安装:http://www.ccvita.com/257.html

Windows下的Memcache安装:http://www.ccvita.com/258.html

Memcache基础教程:http://www.ccvita.com/259.html

Discuz!的Memcache缓存实现:http://www.ccvita.com/261.html

Memcache协议中文版:http://www.ccvita.com/306.html

Memcache分布式部署方案:http://www.ccvita.com/395.html

Tags: Linux, Memcache

=============================================================================

安装时报错:

‘IOV_MAX’ undeclared

可以参考一下:http://blog.csdn.net/wsm6591289/article/details/17996331

memcached 在make的时候出错,解决办法:

# vim memcached.c 

修改如下几行
56 /* FreeBSD 4.x doesn't have IOV_MAX exposed. */
  57 #ifndef IOV_MAX
  58 #if defined(__FreeBSD__) || defined(__APPLE__)
  59 # define IOV_MAX 1024
  60 #endif
  61 #endif
改成
56 /* FreeBSD 4.x doesn't have IOV_MAX exposed. */
  57 #ifndef IOV_MAX
  58 /*#if defined(__FreeBSD__) || defined(__APPLE__)*/
  59 # define IOV_MAX 1024
  60 /*#endif*/


也就是把58和60注释掉,版本不一样,58的可能也会显示不一样。

===============================================================================

报错:libevent-2.0.so.5: cannot open sh

64位centOS5.4系统安装memcached

1.先下载相关资源libevent 和 memcached;

#cd /temp    
#wget http://monkey.org/~provos/libevent-2.0.10-stable.tar.gz    
#wget http://memcached.googlecode.com/files/memcached-1.4.5.tar.gz

2.判断系统是否已经安装了libevent

#rpm -qa | grep libevent    
输出:libevent-1.1a-3.2.1    
#rpm -e --nodeps libevent-1.1a-3.2.1(删除低版本,安装2.0.10)

3.安装libevent

#tar xvzf libevent-2.0.10-stable.tar.gz    
#cd libevent-2.0.10-stable    
#./configure  -prefix=/usr (安装路径/usr/lib)    
#make    
#make install    
#ls -a /usr/lib | grep libevent (测试是否安装上)

4.安装memcached

#tar xvzf memcached-1.4.5.tar.gz
#cd memcached-1.4.5
#./configure -with-libevent=/usr (默认安装/usr/local/bin/memcached)
#make
#make install

5.以上已安装完毕,现在开始启动

#memcached -d -m 128 -l localhost -p 11211 -u root

有可能出错(未加载libevent-2.0.so.5,启动失败):

memcached: error while loading shared libraries: libevent-2.0.so.5: cannot open shared object file: No such file or directory

解决方式:

查看memcached寻找libevent-2.0.so.5模块的路径

#LD_DEBUG=libs   memcached -v

 28788:     find library=libevent-2.0.so.5 [0]; searching
 28788:      search cache=/etc/ld.so.cache
 28788:      search path=/lib64/tls/x86_64:/lib64/tls:/lib64/x86_64:/lib64:/usr/lib64/tls/x86_64:/usr/lib64/tls:/usr/lib64/x86_64:/usr/lib64            (system search path)
 28788:       trying file=/lib64/tls/x86_64/libevent-2.0.so.5
 28788:       trying file=/lib64/tls/libevent-2.0.so.5
 28788:       trying file=/lib64/x86_64/libevent-2.0.so.5
 28788:       trying file=/lib64/libevent-2.0.so.5
 28788:       trying file=/usr/lib64/tls/x86_64/libevent-2.0.so.5
 28788:       trying file=/usr/lib64/tls/libevent-2.0.so.5
 28788:       trying file=/usr/lib64/x86_64/libevent-2.0.so.5
 28788:       trying file=/usr/lib64/libevent-2.0.so.5

memcached: error while loading shared libraries: libevent-2.0.so.5: cannot open shared object file: No such file or directory

从上面的内容可看到memcached是从哪些路径里面去寻找libevent-2.0.so.5的,随便找一个路径,软链接过去即可

#ln -s /usr/lib/libevent-2.0.so.5  /usr/lib64/libevent-2.0.so.5    
#memcached -d -m 128 -l localhost -p 11211 -u root    
# ps -ef | grep memcached    
root     28914     1  0 07:27 ?        00:00:00 memcached -d -m 128 -l localhost -p 11211 -u root (启动ok)

6.测试memcached

#telnet localhost 11211

Trying 127.0.0.1...
Connected to localhost.localdomain (127.0.0.1).
Escape character is '^]'.
set foo 0 0 3     (保存命令)
bar               (数据)
STORED            (结果)
get foo           (取得命令)
VALUE foo 0 3     (数据)
bar               (数据)

备注:

1.启动Memcache的服务器端:

# /usr/local/bin/memcached -d -m 10 -u root -l 192.168.0.200 -p 12000 -c 256 -P /tmp/memcached.pid

-d选项是启动一个守护进程,

-m是分配给Memcache使用的内存数量,单位是MB,默认64MB, 我这里是10MB,

-u是运行Memcache的用户,我这里是root,

-l是监听的服务器IP地址,默认为所有网卡。 我这里指定了服务器的IP地址192.168.0.200,

-p是设置Memcache监听的端口,我这里设置了12000,最好是1024以上的端口,

-c选项是最大运行的并发连接数,默认是1024,我这里设置了256,按照你服务器的负载量来设定,

-P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid,

-p  使用的TCP端口。默认为11211

-m  最大内存大小。默认为64M

-vv 用very vrebose模式启动,调试信息和错误输出到控制台

-d  作为daemon在后台启动

2.如果要结束Memcache进程,执行:

# kill `cat /tmp/memcached.pid`

或是 通过ps -ef | grep memcached 找到pid ,然后kill

也可以启动多个守护进程,不过端口不能重复。