xxqyzsc 发表于 2018-12-25 08:19:41

memcached及memcache扩展安装

  系统:centos6.3_x64

  

  Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libevent

  1) 先安装libevent:
  wget http://cloud.github.com/downloads/libevent/libevent/libevent-2.0.20-stable.tar.gz
  # tar -zxvf libevent-2.0.20-stable.tar.gz
  # cd libevent-2.0.20
  # ./configure --prefix=/usr
  # make
  # make install
  2) 安装memcached
  wget http://memcached.googlecode.com/files/memcached-1.4.15.tar.gz
  # tar zxvf memcached-1.4.15.tar.gz
  # cd memcached-memcached-1.4.15
  # ./configure --prefix=/usr/local --with-libevent=/usr
  # make
  # make install
  启动memcached
  # /usr/local/bin/memcached -d -m 2048 -l 192.168.20.243 -p 11211 -u root
  -d选项是启动一个守护进程,
  -m是分配给Memcache使用的内存数量,单位是MB,
  -u是运行Memcache的用户,我这里是system_u,
  -l是监听的服务器IP地址,如果有多个地址的话,可以用多个 -l YOU_IP
  -p是设置Memcache监听的端口,最好是1024以上的端口,
  -c选项是最大运行的并发连接数,默认是1024,按照你服务器的负载量来设定,
  -P是设置保存Memcache的pid文件
  如果要结束Memcache进程,执行:
  用# ps -e 查看进程
  # kill pid memcached的进程号
  运行后有些系统还会提示-bash: kill: pid: arguments must be process or job IDs
  ,但是用# ps -e查看进程,已经没有memcached的进程了。
  

  3) 安装PHP的memcache扩展
  #wget http://pecl.php.net/get/memcache-2.2.7.tgz
  # tar zxf memcache-2.2.7.tgz
  # cd memcache-2.2.7
  # find / -name phpize
  /usr/local/php/bin/phpize
  # /usr/local/php/bin/phpize //执行,如果有输出结果则可以执行扩展
  Configuring for:
  PHP Api Version: 20100412
  Zend Module Api No: 20100525
  Zend Extension Api No: 220100525
  # ./configure --enable-memcache --with-php-config=/usr/local/php/bin/php-config --with-zlib-dir
  # make
  # make install
  需要在php.ini(vi /etc/php.ini)文件中相应的位置加入:
extension_dir = "/usr/local/php/lib/php/extensions/no-debug-zts-20060613/"
extension=memcache.so
session.cookie_lifetime = 86400
session.gc_maxlifetime = 86400
session.save_handler = memcache
session.save_path = "tcp://192.168.20.243:11211,tcp://192.168.20.244:11211"  启动memcached
  重启apache
  

  优点和缺点:
  memcached部分实现的是内存空间分配和回收,以及存储服务监听和提供.对于分布式的实现,取决于客户端的使用和构造.我们使用的客户端是完全支持分布式的.只是可能会出现某些问题.
  诸如一旦出现网络问题, 网络问题导致某个分布式服务器中的一台失去联系之后,到这台机器恢复正常工作的这段时间内, 写入分布式服务器的数据将基本不可以获取. 可以通过采用分布式hash表的方式解决这个问题
  

  测试memcached启动是否连接正常
  # telnet 192.168.20.243 11211
Trying 127.0.0.1...
30 END
VALUE test 0 10
test_value            #取得的key为test中的数据
END
quit
http://blog.运维网.com/attachment/201310/123605191.png



页: [1]
查看完整版本: memcached及memcache扩展安装