memcache 细究(一)

memcached是高性能的分布式的内存缓存服务器。由国外社区网站LIVEJOURNAL的开发团队开发。

使用目的:

通过缓存数据库查询结果,减少数据库的访问次数,以提高动态web应用的速度、提高可扩展性。

memcache 是一个自由和开放源代码、高性能、分布式的内存对象缓存系统。用于加速动态web应用程序,减少数据库负载。

memcahce的特征

1、基于C/S架构,协议简单

2、基于libevent事件处理{libevent是一个基于事件触发的网络库,适用于windows、Linux、bsd(Unix的衍生系统)等多种平台}

3、内置内存存储方式

4、基于客户端的memcached分布式

适用场景

1、需要分布式部署的(什么是分布式:假如一个任务有10个子任务,将这10个子任务分别单独放到10个服务器,大大缩短任务执行时间,)

2、需要频繁访问相同数据

3、需要数据共享的

介绍C/S架构

安装启动(见PDF文档)

各种命令的使用

set/add/replace/delete/get/gets/cas/stats/stats items/append/prepend/flush_all等等

memcahced一些特性和限制

①在Memcached 中可以保存的item数据量是没有限制的,只有内存足够

②Memcached单进程最大使用内存为2G,要使用更多内存,可以分多个端口开启多个Memcached进程

③最大30天的数据过期时间, 设置为永久的也会在这个时间过期,常量REALTIME_MAXDELTA

④60*60*24*30 控制

⑤最大键长为250字节,大于该长度无法存储,常量KEY_MAX_LENGTH 250 控制

⑥单个item最大数据是1MB,超过1MB数据不予存储,常量POWER_BLOCK 1048576 进行控制,

⑦它是默认的slab大小

⑧最大同时连接数是200,通过conn_init()中的freetotal 进行控制,最大软连接数是1024,通过

⑨settings.maxconns=1024 进行控制⑩跟空间占用相关的参数:settings.factor=1.25, settings.chunk_size=48, 影响slab的数据占用和步进方式

//memcached配置
/********************************************/
$mem_ip=‘127.0.0.1‘;
$mem_port=11211;
$mem_prefix=‘‘;
/********************************************/

/********************************************/
//session memcached配置,请配置到一个独立的memcache服务(不同IP或不同端口号),
//几个镜像站都必须设置相同,否则会导致session丢失
//其他任何程序都不能使用这个服务,以免冲突。
/********************************************/
$session_mem_ip=‘127.0.0.1‘;
$session_mem_port=11212;

function Instance_Memcached()
{
static $mem=false;
if($mem==false && isset($GLOBALS[‘mem_ip‘]) && isset($GLOBALS[‘mem_port‘]) && extension_loaded(‘memcache‘))
{
$mem=new Memcache;
$mem->pconnect($GLOBALS[‘mem_ip‘],$GLOBALS[‘mem_port‘]) or die(‘Can not connect to memcache server!‘);
}
return $mem;
}

时间: 2024-10-12 20:19:29

memcache 细究(一)的相关文章

nginc+memcache

memcache 分为服务端和客户端.服务端用来存放缓存,客户端用来操作缓存.因此,可以使用 Nginx 直接访问 Memcache,并用$uri 和$args 等 Nginx 内置变量设定缓存 key规则,这样,当缓存命中时,Nginx 可以跳过通过 fastcgi 和 PHP 通信的过程,直接从 memcache中获取数据并返回.OpenResty是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库.第三方模块以及大多数的依赖项.用于方便地搭建能够处

Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. Memc

Memcache学习总结2-Memcache的使用基本介绍

Memcache学习总结2-Memcache的使用基本介绍 上一次总结中我们已经安装部署好了Memcached,并且把PHP扩展Memcache也安装好了,这一节我们详细学习一下PHP扩展Memcache.Memcache客户端包含两组接口,一组是面向过程的接口,一组是面向对象的接口,具体可以参考PHP手册:http://php.net/manual/zh/book.memcache.php . 我们为了简单方便,就使用面向对象的方式,也便于维护和编写代码,那我们先来一段示例代码吧. Memca

MemCache超详细解读

MemCache是什么 MemCache是一个自由.源码开放.高性能.分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高了网站访问的速度.MemCaChe是一个存储键值对的HashMap,在内存中对任意的数据(比如字符串.对象等)所使用的key-value存储,数据可以来自数据库调用.API调用,或者页面渲染的结果.MemCache设计理念就是小而强大,它简单的设计促进了快速部署.易于开发并解决面对大规模的数据缓存的

mysql+nginx+php+memcache

***************** mysql+nginx+php+memcache ****************** 1.Mysql 安装 软件包依赖性: # yum install -y gcc-c++ make ncurses-devel bison openssl-devel zlib-devel cmake-2.8.12.2-4.el6.x86_64.rpm # tar zxf mysql-boost-5.7.17.tar.gz # cd mysql-5.7.17/ cmake -

nginx+tomcat+memcache

nginx支持静态页面tomcat支持动态页面如果所在的nginx服务器想要进行动态页面则需与tomcat结合此时nginx只是起到转发的作用对jsp的处理是由tomcat来处理的. 一 搭建jdk 先搭建java环境 1  tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/    ###解压到/usr/local下### 2 ln -s jdk1.7.0_79/ java            ###软链接方便版本升级后的使用### 3 vim /

memcache的简单应用

如今互联网崛起的时代,各大网站都面临着一个大数据流问题,怎么提高网站访问速度,减少对数据库的操作:作为PHP开发人员,我们一般能想到的方法有页面静态化处理.防盗链.CDN内容分发加速访问.mysql数据库优化建立索引.架设apache服务器集群.还有就是现在流行的各种分布式缓存技术:如memcached/redis:1.什么是Memcached?a.Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从

【memcache】Memcached

一.Memcached 简介 1. 官网:http://www.memcached.org 2. Memcached是一个自由开源的,高性能,分布式内存对象缓存系统. 二.作用: 1. 将数据存入内存,需要的时候从内存读取. 2. 一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度.提高可扩展性. 3. 原理,如果有缓存,就读取缓存,如果没有,就读取 数据库. 三.安装 linux 安装 1. 安装libevent 官方网站 http://libevent.

Redis和Memcache对比及选择

Redis和Memcache对比及选择 http://www.cnblogs.com/EE-NovRain/p/3268476.html 在选择内存数据库的时候到底什么时候选择redis,什么时候选择memcache,然后就查到下面对应的资料,是来自redis作者的说法(stackoverflow上面). You should not care too much about performances. Redis is faster per core with small values, but