1.memcached 解释
注:Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon)是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信。
注:Memcached基本使用方法:
-l 监听的地址memcached 无身份验证功能,严禁在无防护
-p 监听的端口状态下,直接监听外网端口!默认端口为11211
-d 以daemon 形式运行,一般皆需增加此参数
-u 以何用户身份运行,一般选nobody 等低权用户
-m 最大可用内存,以兆为单位
-c 最大的同时并发数,默认1024
-f 增长因子
-P PID 文件
一、安装libevent
memcached依赖于libevent API,因此要事先安装之,项目主页:http://libevent.org/ libevent-2.0.16-stable.tar.gz。安装过程:
rpm -ql libevent ---查看事件驱动
检查 sasl 开发库必须安装 rpm -qa | grep sasl
安装方式有2种
(1)yum 安装 (寻找方式 http://rpmfind.net)
yum install memcached -y
yum install libevent -y
(2)源码编译
1
2
3
4
5
6
7
| # tar xf libevent-2.0.20-stable.tar.gz
# cd libevent-2.0.20
# ./configure --prefix=/usr/local/libevent
# make && make install
# echo "/usr/local/libevent/lib"> /etc/ld.so.conf.d/libevent.conf
# ldconfig -- 写入系统
|
安装memcached
1
2
3
4
| # tar xf memcached-1.4.15.tar.gz
# cd memcached-1.4.15
# ./configure --prefix=/usr/local/memcached--with-libevent=/usr/local/libevent
# make && make install
|
(3)memcached SysV的startup脚本代码如下所示,将其建立为/etc/init.d/memcached文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
| #!/bin/bash
#
# Init file for memcached
#
# chkconfig: - 86 14
# description: Distributed memory cachingdaemon
#
# processname: memcached
# config: /etc/sysconfig/memcached
. /etc/rc.d/init.d/functions
## Default variables
PORT="11211"
USER="nobody"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS=""
RETVAL=0
prog="/usr/local/memcached/bin/memcached"
desc="Distributed memory caching"
lockfile="/var/lock/subsys/memcached"
start() {
echo -n $"Starting $desc (memcached): "
daemon $prog -d -p $PORT -u $USER -c $MAXCONN -m $CACHESIZE -o"$OPTIONS"
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch $lockfile
return $RETVAL
}
stop() {
echo -n $"Shutting down $desc (memcached): "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f $lockfile
return $RETVAL
}
restart() {
stop
start
}
reload() {
echo -n $"Reloading $desc ($prog): "
killproc $prog -HUP
RETVAL=$?
echo
return $RETVAL
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
condrestart)
[ -e $lockfile ] && restart
RETVAL=$?
;;
reload)
reload
;;
status)
status $prog
RETVAL=$?
;;
*)
echo $"Usage: $0 {start|stop|restart|condrestart|status}"
RETVAL=1
esac
exit $RETVAL
|
使用如下命令配置memcached成为系统服务:
# chmod +x /etc/init.d/memcached
# chkconfig --add memcached
# service memcached start
访问http://php页面
创建测试页面 ok
1
2
3
| <?php
phpinfo();
?>
|
Memcached –h 测试
二、使用telnet命令测试memcached的使用
Memcached提供一组基本命令用于基于命令行调用其服务或查看服务器状态等。
# telnet 127.0.0.1 11211
Memcached 命令 add /get/ delete
add命令:
add keyzzx 0 30 3
0 303 ----30秒 5个字符
Hello world!
get命令:
get keyzzx
delete 删除
修改memcached内存配置文件
vim /etc/sysconfig/memcached
重启 memcached service memcachedrestart
查看memcached 内存显示
三、安装Memcache的PHP扩展
下载wget http://memcached.org/latest
检查phpize 遇到的问题。
解决方案:
安装PHP的memcache扩展
# tar xf memcache-2.2.5.tgz
# cd memcache-2.2.5
/usr/local/php/bin/phpize
# ./configure--with-php-config=/usr/local/php/bin/php-config --enable-memcache
# make && make install
安装完后会提示一下内容:
编辑/usr/local/php5/etc/php.ini,在“动态模块”相关的位置添加如下一行来载入memcache扩展:
而后对memcached功能进行测试,在网站目录中建立测试页面test.php,添加如下内容:
1
2
3
4
5
6
7
8
9
10
11
12
13
| <?php
$mem = new Memcache;
$mem->connect("127.0.0.1",11211) or die("Could notconnect");
$version = $mem->getVersion();
echo "Server's version:".$version."<br/>\n";
$mem->set('testkey', 'Hello World', 0,600) or die("Failed to save data at the memcached server");
echo "Store data in the cache (datawill expire in 600 seconds)<br/>\n";
$get_result = $mem->get('testkey');
echo "$get_result is from memcachedserver.";
?>
|
取值查看结果:
三、配置php将会话保存至memcached中
##############配置php将会话保存至memcached中########################
编辑php.ini文件,确保如下两个参数的值分别如下所示:
注意session.name = PHPSESSID 的名称 都会场景中得到应用
重启php-fpm
service php-fpm restart
新建php页面setsess.php,为客户端设置启用session:<?php
1
2
3
4
5
6
7
8
| session_start();
if (!isset($_SESSION['www.zzxtbl.com'])) {
$_SESSION['www.zzxtbl.com'] = time();
}
print $_SESSION['www.zzxtbl.com'];
print "<br><br>";
print "Session ID: " .session_id();
?>
|
新建php页面showsess.php,获取当前用户的会话ID:
1
2
3
4
5
6
7
8
| <?php
session_start();
$memcache_obj = new Memcache;
$memcache_obj->connect('127.0.0.1',11211);
$mysess=session_id();
var_dump($memcache_obj->get($mysess));
$memcache_obj->close();
?>
|
四 、MemAdmin使用
基于 PHP5 & JQuery 的 Memcached 管理监控工具
MemAdmin是一款可视化的Memcached管理与监控工具,使用PHP开发,体积小,操作简单。 介绍MemAdmin是一款可视化的Memcached管理与监控工具,基于 PHP5 & JQuery 开发,体积小,操作简单。 主要功能: · 服务器参数监控:STATS、SETTINGS、ITEMS、SLABS、SIZES实时刷新 · 服务器性能监控:GET、DELETE、INCR、DECR、CAS等常用操作命中率实时监控 · 支持数据遍历,方便对存储内容进行监视 · 支持条件查询,筛选出满足条件的KEY或VALUE · 数组、JSON等序列化字符反序列显示 · 兼容memcache协议的其他服务,如Tokyo Tyrant (遍历功能除外) · 支持服务器连接池,多服务器管理切换方便简洁 下载地址:http://www.junopen.com/memadmin/
Memadmin下载连接http://www.junopen.com/memadmin/memadmin-1.0.12.tar.gz
将memadmin 程序放到nginx的根目录下访问
添加一台memcache服务器
连接参数
添加key
读取数据信息:
命中监控
条件遍历条件查询
|