memcache的安装和使用
MemCache和MemCached的区别:
1、MemCache是项目的名称
2、MemCached是MemCache服务器端可以执行文件的名称
MemCache集群
每个服务之间不会相互通信, 完全依赖于客户端程序的实现, 所以对服务器集群的管理,路由算法至关重要(通常采用: 一致性Hash算法)
Memcached的分布式算法:
当向memcached集群存入/取出key/value时,memcached客户端程序根据一定的算法计算存入哪台服务器,然后再把key/value值存到此服务器中。也就是说,存取数据分二步走,第一步,选择服务器,第二步存取数据。
MemCache的特性和限制
1、MemCache中可以保存的item数据量是没有限制的,只要内存足够
2、MemCache单进程在32位机中最大使用内存为2G,这个之前的文章提了多次了,64位机则没有限制
3、Key最大为250个字节,超过该长度无法存储
4、单个item最大数据是1MB,超过1MB的数据不予存储
5、MemCache服务端是不安全的,比如已知某个MemCache节点,可以直接telnet过去,并通过flush_all让已经存在的键值对立即失效
6、不能够遍历MemCache中所有的item,因为这个操作的速度相对缓慢且会阻塞其他的操作
7、MemCache的高性能源自于两阶段哈希结构:第一阶段在客户端,通过Hash算法根据Key值算出一个节点;第二阶段在服务端,通过一个内部的Hash算法,查找真正的item并返回给客户端。从实现的角度看,MemCache是一个非阻塞的、基于事件的服务器程序
8、MemCache设置添加某一个Key值的时候,传入expiry为0表示这个Key值永久有效,但是这个Key值也会在30天之后失效(是由memcached的核心代码决定的,无法更改)
Memcached的内存算法:
Memcached利用slab allocation机制来分配和管理内存,它按照预先规定的大小,将分配的内存分割成特定长度的内存块,再把尺寸相同的内存块分成组,数据在存放时,根据键值 大小去匹配slab大小,找就近的slab存放,所以存在空间浪费现象。
传统的内存管理方式是,使用完通过malloc分配的内存后通过free来回收内存,这种方式容易产生内存碎片并降低操作系统对内存的管理效率。
Memcached的缓存策略:
Memcached的缓存策略是LRU(最近最少使用)+到期失效策略。当你在memcached内存储数据项时,你有可能会指定它在缓存的失效时间,默认为永久。当memcached服务器用完分配的内时,失效的数据被首先替换,然后是最近未使用的数据。在LRU中,memcached使用的是一种Lazy Expiration策略,自己不会监控存入的key/vlue对是否过期,而是在获取key值时查看记录的时间戳,检查key/value对空间是否过期,这样可减轻服务器的负载。
memcached命令行
命令 作用
get 返回Key对应的Value值
add 添加一个Key值,没有则添加成功并提示STORED,有则失败并提示NOT_STORED
set 无条件地设置一个Key值,没有就增加,有就覆盖,操作成功提示STORED
replace 按照相应的Key值替换数据,如果Key值不存在则会操作失败
stats 返回MemCache通用统计信息(下面有详细解读)
stats items 返回各个slab中item的数目和最老的item的年龄(最后一次访问距离现在的秒数)
stats slabs 返回MemCache运行期间创建的每个slab的信息(下面有详细解读)
version 返回当前MemCache版本号
flush_all 清空所有键值,但不会删除items,所以此时MemCache依旧占用内存
quit 关闭连接
memcached的安装与使用
1.准备三个安装包
libevent-2.0.22-stable.tar.gz
memcached-1.4.29.tar.gz
memcache-2.2.7.tgz php-memcache模块
2.安装libevent
tar zxvf libevent-2.0.22-stable.tar.gz
cd libevent-2.0.22-stable
mkdir /usr/local/libevent
./configure --prefix=/usr/local/libevent
make && make install
3.安装memcached
tar zxvf memcached-1.4.29.tar.gz
cd memcached-1.4.29
mkdir /usr/local/memcached
./configure --prefix=/usr/local/memcached --with-libevent=/usr/local/libevent
make && make install
4.启动服务
memcached -d -u root -m 256m -c 10240 -l 192.168.32.130 -p 11212 -P /tmp/11212.pid
kill `cat /tmp/11212.pid`
5.检查服务
查看启动的memcache服务:
netstat -lp | grep memcached
tcp 0 0 192.168.32.130:11212 *:* LISTEN 21230/memcached udp 0 0 192.168.32.130:11212 *:* 21230/memcached
查看memcache的进程号(根据进程号,可以结束memcache服务:“kill -9 进程号”)
ps -ef | grep memcached
root 21230 1 0 19:04 ? 00:00:00 /usr/local/memcached/bin/memcached -d -u root -m 256m -c 10240 -l 192.168.32.130 -p 11212 -P /tmp/11212.pid
6.连接测试
telnet 192.168.32.130 11212
set liuguohua 0 0 21
369369.blog.51cto.com
STORED
get liuguohua
VALUE liuguohua 0 21369369.blog.51cto.com
7.安装php扩展
tar zxf memcache-2.2.7.tgz
cd memcache-2.2.7
/usr/local/php/bin/phpize
./configure --enable-memcache=/usr/local/memcached --with-php-config=/usr/local/php/bin/php-config --with-apxs2=/usr/sbin/apxs
make && make inst
安装完后会有类似这样的提示:
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20060922/
把这个extension的路径记住, 然后修改php.ini
extension_dir = "./"
修改为
extension_dir = "/usr/local/php/lib/php/extensions/"
并添加一行
extension="no-debug-non-zts-20060922/memcache.so"
8.php端测试
<?php$memcache = new Memcache;$memcache->connect('192.168.32.130', 11212) 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);?>
显示结果:
Server's version: 1.2.6 Store data in the cache (data will expire in 10 seconds)Data from the cache:object(stdClass)[3] public 'str_attr' => string 'test' (length=4) public 'int_attr' => int 123
--------------------------------------------------------------------------------------------
memcached参数
-d 选项是启动一个守护进程,
-m 是分配给Memcache使用的内存数量,单位是MB
-u 是运行Memcache的用户,如果当前为 root 的话,需要使用此参数指定用户。
-l 是监听的服务器IP地址
-p 是设置Memcache监听的端口, 最好是1024以上的端口
-c 是最大运行的并发连接数,默认是1024
-P 是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid
memcache实现会话保持
修改php.ini配置文件
session.save_handler = memcache
session.save_path = "tcp://192.168.32.130:11212"
扩展阅读
浅谈千万级PV/IP规模高性能高并发网站架构
http://oldboy.blog.51cto.com/2561410/736710
大规模网站sesson会话保持思路及实践配置
http://oldboy.blog.51cto.com/2561410/1331316
;
转载于:https://www.cnblogs.com/upup2015/p/7782440.html
memcache的安装和使用相关推荐
- Windows下Memcache的安装及PHP扩展配置方法
这篇文章主要介绍了Windows下Memcache的安装及PHP扩展配置方法,需要的朋友可以参考下 一.下载 找到完整的memcache的Windows安装包,解压放在硬盘上,比如 F:\memcac ...
- php无法加载Memcache缓存模块问题及Memcache的安装
今天早上去迁移网站发现打开网站报错 然后我去phpinfo.php看了一下,果然我的测试页里面有加载到Memcache这个模块,如下图: 这时候,既然发现了问题的所在我们就要去排查问题,当前这个问题呢 ...
- php扩展memcached和memcache的安装配置方法
这篇文章主要介绍了php扩展memcached和memcache的安装配置方法,需要的朋友可以参考下 php连接memcached缓存服务器的客户端有两个,一个是memcache是比较底层的开发库,m ...
- windows下memcache的安装总结
一.memcache软件的安装: 1.下载memcache的windows版本,把memcached.exe放在F:盘符,(memcached.exe文件位置不可变动). 2.进入cmd命令终端,进入 ...
- Memcache的安装与启动【小强测试培训班学员作品】
好久木有和大家见面了,这次搞一下Memcache的安装,我们使用最绿色的安装方式yum进行安装. 大致步骤 yum install memcached #静静的等待安装完成即可 chkconfig - ...
- php win memcached 5.4,CentOS 5.4下Memcache的安装步骤(Linux+Nginx+PHP+Memcached) 电脑维修技术网...
一.源码包准备 服务器端主要是安装memcache服务器端,目前的最新版本是 memcached-v1.4.4 . 下载:http://memcached.googlecode.com/files/m ...
- 多服务器session共享之memcache共享安装和实现篇(apache+php-windows)
转自www.5iphp.com 原理是:直接用 memcache 来作 PHP 的 session.save_handler. 1. 安装 memcached 2. 将 php.ini 中extens ...
- win7 64位系统 memcache/memcached安装
2019独角兽企业重金招聘Python工程师标准>>> memcached介绍: Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过 ...
- memcache的安装及管理
一.Memcache概述 Memcache(内存,缓存):是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个巨大的hash表.(key=value)(是用C语言开发的,并且需要libeven ...
- 缓存系统memcache的安装,配置和使用
软件介绍[我的Linux,让Linux更易用]memcached是一套分布式的快取或缓存系统,当初是Danga Interactive为了LiveJournal所发展的,但目前被许多软件(如Media ...
最新文章
- python编程问题--第二次
- 解决git clone慢问题
- PyObject_CallMethod
- 以太坊联合创始人发明了新语言叫板Vyper,主链之后语言将引领新一轮大战?...
- 如何优化 .NET Core 中的 lambda 查询表达式 ?
- if else的使用以及如何从键盘获取数值
- 安装python37路径报错_解决pycharm安装python库报错问题
- 2018-12-25 上机作业
- 上班时间应该包含交通时间
- Suse Enterprise Server 11的安装
- 线性判别用于提取词向量_各种机器学习算法的应用场景分别是什么(比如朴素贝叶斯、决策树、K 近邻、SVM、逻辑回归最大熵模型)?...
- Visio Professional 2016 破解教程
- ECRS分析原则(转载)
- 支付宝app支付-php
- 华为交换机设置端口镜像捕获数据包
- 非全研究生业余研究:利用十一假期训练了室内定位模型
- Python前世今生
- 计算机视觉-OpenCV(七)
- Python多分类问题pr曲线绘制(含代码)
- yield方法释放锁吗_java多线程,让步yield
热门文章
- 对服务器端接口的调用,自己手写了一个脚本,但返回信息的中文总是乱码(这个方法很不错,重要的是解决思路,寻找手写脚本与录制脚本 生成目录文件的区别)...
- thinkphp的model模型的设计经验总结
- win7下声音图标消失的解决办法
- [转]设置修改CentOS系统时区
- Amoeba新版本MYSQL读写分离配置
- 我们去庐山玩啦,公司组织,带上老婆
- java 序列化 学习
- ImageView的属性android:scaleType作用
- 苹果 CEO 库克“喜当爹”,被女子索赔31.6亿分手费!
- 因未发项目奖金,一程序员删代码泄愤被判刑5个月