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 21

369369.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

;

时间: 2024-10-11 04:10:15

memcache的安装和使用的相关文章

企业LAMP+gd + fretds + fastcgi + memcache环境安装配置

于2017.04.21 从新浪博客搬迁过来 ---------------------------------------------------------------- 现在很多企业线上web环境都在使用lamp+fretds这样的环境的,如果公司正处于发展阶段,那么有时候需要扩大线上环境,或者替换老的机器,在这个时候就需要搭建线上的web环境,如果每次都手动安装环境费时费力:在这里我基于我们公司线上web环境整理了这篇文档. 安装前的准备工作 关闭防火墙和selinux iptables

centos6.5 Memcache的安装

Memcache的安装 1.分别下载memcached和libevent Wget http://memcached.org/files/memcached-1.4.25.tar.gz wget https://cloud.github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz 2.先安装libevent:# tar zxvf libevent-2.0.21-stable.tar.gz # cd libevent-

Linux下memcache的安装

memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度.目前用memcache解决互联网上的大用户读取是非常流行的一种用法,在互联网企业中有着广泛的应用.?关于memcache的详细介绍,有兴趣的朋友请参考这篇文章:http://blog.csdn.net/xifeijian/article/details/219949411.下载memcache墙裂推荐官方下载(http://memcached.org/),目前为止,最新的下载版本是1.4.17,如图

memcache的安装及管理

一.Memcache概述 Memcache(内存,缓存):是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个巨大的hash表.(key=value)(是用C语言开发的,并且需要libevent库的支持)                                                 Hash表 key value str “abc” arr array(‘a’,'b') obj object值 memcache就是一个软件(服务软件)C/S软件 Mysql       

windows下memcache的安装总结

一.memcache软件的安装: 1.下载memcache的windows版本,把memcached.exe放在F:盘符,(memcached.exe文件位置不可变动). 2.进入cmd命令终端,进入到F:盘符. 3.memcached.exe -d install 命令进行memcache的安装. 4.memcached.exe -d start 命令进行memcache的开机自动启动. 5.软件安装完成. 二.PHP扩展的配置: 1.下载 php_memcache.dll 扩展文件:http

Memcache的安装与启动【小强测试培训班学员作品】

好久木有和大家见面了,这次搞一下Memcache的安装,我们使用最绿色的安装方式yum进行安装. 大致步骤 yum install memcached #静静的等待安装完成即可 chkconfig --level 2345 memcached on #设置为开机启动 servive memcached start #启动 安装成功之后的配置文件在:/etc/sysconfig/memcached 成功安装并启动后可以使用stats命令来观察Memcache的状体,大致指标如下: cmd_get

Memcache的安装与启动

安装与启动 Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libevent,libevent的最新版本是libevent-1.3.(如果你的系统已经安装了libevent,可以不用安装) #wget https://github.com/libevent/libevent/releases/download/release-2.0.22-stable/libevent-2.0.22-stable.tar.gz 下载libevent之后,#tar -zxvf一下

Linux下安装Memcache以及安装过程中一些问题的解决方法

一.下载安装libevent cd /tmp #切换到tmp目录 wget http://www.monkey.org/~provos/libevent-1.2.tar.gz #下载 tar zxvf libevent-1.2.tar.gz #解压 cd libevent-1.2 #切换到libevent目录 ./configure --prefix=/usr #配置安装路径 #如果此步骤报错,检查一下有没有安装编译器,没有的话运行以下命令进行安装 yum install gcc make #编

Memcache的安装和使用【转】

转自:https://www.cnblogs.com/caoxiaojian/p/5715573.html Memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度.为了提高性能,memcached中保存的数据都存储在memcached内置的内存存储空间中.由于数据仅存在于内存中,因此重启memcached.重启操作系统会导致全部数据消失.另外,内容容量达到指定值之后,就基于LRU(Least Recently Used)算法自动删除不使用的缓存. lib

Windows下Memcache的安装及PHP扩展配置

一.下载 找到完整的memcache的Windows安装包,解压放在硬盘上,比如 F:\memcached.exe 二.安装 WIN7 64位双击打开这个exe可能只有一个空的窗口,不能输入任何命令,所以这个exe不是这样用的.要运行cmd控制台,输入 F:\memcached.exe -d install 安装,再输入 F:\memcached.exe -d start 启动. Tips:如果没有报错信息,则至此memcached已经安装并启动,而且默认是开机自动启动的 三.PHP扩展下载及版