linux下安装memcache

memcache一点点积累

什么是memcache 为什么要用:

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像视频文件以及数据库检索的结果等。Memcachedanga的一个项目,最早是LiveJournal 服务的,最初为了加速 LiveJournal 访问速度而开发的,后来被很多大型的网站采用。

Memcache安装的过程

服务器端主要是安装memcache服务器端,目前的最新版本是 memcached-1.3.0
下载:http://www.danga.com/memcached/dist/memcached-1.2.2.tar.gz
另外,Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libeventlibevent的最新版本是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
这样就完成了LinuxMemcache服务器端的安装。详细的方法如下:

1.分别把memcachedlibevent下载回来,放到 /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 –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

安装MemcachePHP扩展
1.
http://pecl.php.net/package/memcache 选择相应想要下载的memcache版本。
2.
安装PHPmemcache扩展

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 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
是设置保存Memcachepid文件,我这里是保存在 /tmp/memcached.pid

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

# kill `cat /tmp/memcached.pid`

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

3.重启apacheservice 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是否还在运行
 ps -ef | grep memcached

如何开机自启动

 vi /etc/rc.local

如何查看有多少个客户端在连接

netstat -an | grep 11211 | wc -l

memcache已经启动了,但是php还是无法连接memcache服务器?

system-config-securitylevel-tui

SELinux的选项disabled掉,保存退出,再看看应该可以连上了。

DEBUG

LD_DEBUG=libs /usr/local/bin/memcached -v
memcache
方法的一些说明

Memcache::add — 添加一个值,如果已经存在,则返回false Memcache::set方法类似.区别是如果 Memcache::add方法的返回值为false,表示这个key已经存在,而Memcache::set方法则会直接覆写。
Memcache::addServer —
添加一个可供使用的服务器地址.8个参数,除了第一个参数意外,其他都是可选的,第一个参数表示服务器的地址,第二个参数表示端口,第三个参数表示是否是一个持久连接,第四个参数表示这台服务器在所有服务器中所占的权重,第五个参数表示连接的持续时间,第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,第七个参数用来控制服务器的在线状态,第8个参数允许设置一个回掉函数来处理错误信息。
Memcache::close —
关闭一个Memcache对象
Memcache::connect —
创建一个Memcache对象
memcache_debug —
控制调试功能 前提是php在编译的时候使用了–enable-debug选项,否则这个函数不会有作用。
Memcache::decrement —
对保存的某个key中的值进行减法操作
Memcache::delete —
删除一个key.第一个参数表示key ,第二个参数可选,表示删除延迟的时间。
Memcache::flush —
清除所有缓存的数据
Memcache::get —
获取一个key值 有一个参数 表示key
Memcache::getExtendedStats —
获取进程池中所有进程的运行系统统计

Memcache::getServerStatus —
获取运行服务器的参数
Memcache::getStats —
返回服务器的一些运行统计信息 有三个参数,第一个参数表示要求返回的类型:reset, malloc, maps, cachedump, slabs, items, sizes;第二个参数和第三个参数是在第一个参数设置为“cachedump”时使用的。
Memcache::getExtendedStats
方法的作用是获取进程池中所有进程的运行系统统计。
Memcache::getVersion —
返回运行的Memcache的版本信息
Memcache::increment —
对保存的某个key中的值进行加法操作
Memcache::pconnect —
创建一个Memcache的持久连接对象
Memcache::replace — R
对一个已有的key进行覆写操作 有四个参数,作用和方法的相同。
Memcache::set —
添加一个值,如果已经存在,则覆写
Memcache::setCompressThreshold —
对大于某一大小的数据进行压缩
Memcache::setServerParams —
在运行时修改服务器的参数

呵呵以上就这么多了,注意不要用php脚本执行,apache加载执行.我用的是nginx.

实在不行可以参考这个文献,个人感觉不错http://www.indang.net/html/php-memcache-finishing.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值