linux下的Memcache安装:php
用 pecl 命令行工具安装: pecl install memcachehtml
或直接从源码安装: phpize ./configure make make installlinux
Windows下的Memcache安装:算法
memcached的基本设置:数据库
-p 监听的端口 -l 链接的IP地址, 默认是本机 -d start 启动memcached服务 -d restart 重起memcached服务 -d stop|shutdown 关闭正在运行的memcached服务 -d install 安装memcached服务 -d uninstall 卸载memcached服务 -u 以的身份运行 (仅在以root运行的时候有效) -m 最大内存使用,单位MB。默认64MB -M 内存耗尽时返回错误,而不是删除项 -c 最大同时链接数,默认是1024 -f 块大小增加因子,默认是1.25-n 最小分配空间,key+value+flags默认是48 -h 显示帮助windows
php.ini中的配置:缓存
[Memcache]服务器
; 一个高性能的分布式的内存对象缓存系统,经过在内存里维护一个统一的巨大的hash表, ; 它可以用来存储各类格式的数据,包括图像、视频、文件以及数据库检索的结果等。网络
; 是否在遇到错误时透明地向其余服务器进行故障转移。 memcache.allow_failover = Onsession
; 接受和发送数据时最多尝试多少个服务器,只在打开memcache.allow_failover时有效。memcache.max_failover_attempts = 20
; 数据将按照此值设定的块大小进行转移。此值越小所需的额外网络传输越多。 ; 若是发现没法解释的速度下降,能够尝试将此值增长到32768。 memcache.chunk_size = 8192
; 链接到memcached服务器时使用的默认TCP端口。 memcache.default_port = 11211
; 控制将key映射到server的策略。默认值"standard"表示使用先前版本的老hash策略。 ; 设为"consistent"能够容许在链接池中添加/删除服务器时没必要从新计算key与server之间的映射关系。 ;memcache.hash_strategy = "standard"; 控制将key映射到server的散列函数。默认值"crc32"使用CRC32算法,而"fnv"则表示使用FNV-1a算法。 ; FNV-1a比CRC32速度稍低,可是散列效果更好。 ;memcache.hash_function = "crc32"
;memcache也能够做为session的存储模块,具体参看:memcache PHP 的 session.save_handler.
memcache的测试代码: [php] view plaincopy $memcache = new Memcache;
$memcache->connect('localhost', 11211) or die ("Could not connect");
$version = $memcache->getVersion();
echo "Server's version: ".$version."<br>/n";
$tmp_object = new stdClass;
$tmp_object->str_attr = 'test';
$tmp_object->int_attr = 123;
$memcache->set('key', $tmp_object, false, 10) or die ("Failed to save data at the server");
echo "Store data in the cache (data will expire in 10 seconds)<br>/n";
$get_result = $memcache->get('key');
echo "Data from the cache:<br>/n";
var_dump($get_result);
come from http://blog.csdn.net/hnxxwyq/article/details/2534868
http://weixiang096.blog.163.com/blog/static/12747355520119286330387/