memcache 杂记

它是一个一个高性能的分布式内存对象缓存系统。
 端口号 11211
 目前被许多网站使用以提升网站的访问速度,尤其对于一些大型的、
 需要频繁访问数据库的网站访问速度提升效果十分显著
 根据一个sql取出的数据,把sql取出的数据,给缓存到memcache里面,
 当下次再操作该sql语句的时候,则直接从memcache里面获取

跟mysql比较一下
 
     它是一个c/s架构

mysql的数据是存在磁盘的 memcache存在内存里

mysql的数据存储是,由数据库,数据表,数据的记录,
    存储数据是按照表的结构进行存储的。

memcache的数据存储格式是:keyalue的格式,来存储的,
    相当于在内存里面有一张两列的哈希表。类似于php的里面的关联数组

memcache细节讨论

1、缓存周期(有效期)
    缓存周期的设置有两种方式:
    如果缓存周期设置为0表明此数据永不过期

第一种使用:秒数,最大不能超过30天,即2592000秒,

第二种使用:使用时间戳,该时间戳是到的哪个时间点。比如我们要把一个数据缓存60天,
    $mem->add($key,$value,0,time()+60*24*3600)

2、 惰性删除,
    就是说,缓存的数据,到期后,不会自动删除,当get数据的时候,查看有没有到期,如果到期了,则再删除该数据。
     memcache不会开启进程来监视键是否过期,省memcache的资源,也省cpu.

3、Least Recently Used(LRU)
    最近 最少使用原则,

当前存储的数据的在memcache里面空间已经占满后,则memcache会把不活跃(get或set次数比较少的)的数据(不管是否到期)清除,让新的数据给存储进来。

4、安全性

memcache定位就是做数据的缓存的,不是数据的持久存储的,因此没有做一些用户的验证,目的提高连接速度,发挥自己的独特功能。

memcahe该软件本身没有提供一些安全机制,如果要限制使用,则只能在操作系统的层面来解决,比如window系统、安装防火墙的软件,在linux下面使用iptables,seclinux(安全机制)

5、memcache比较适合于存储哪些数据。
    存储的数据的特点:
     访问比较频繁,
    安全性不高,丢失无所谓,
    修改比较频繁的数据,比如一些用户的在线状态。

memcache实现原理

1、访问数据的速度比传统的关系型数据库要快,因为Oracle、MySQL这些传统的关系型数据库为了保持数据的持久性,数据存放在硬盘中,IO操作速度慢

2、memcache的数据存放在内存中同时意味着只要memcache重启了,数据就会消失

3、既然memcache的数据存放在内存中,那么势必受到机器位数的限制,32位机器最多只能使用2GB的内存空间,64位机器可以认为没有上限

4、memcache采用的内存分配方式是固定空间分配

1、memcache将内存空间分为一组slab

2、每个slab下又有若干个page,每个page默认是1M,如果一个slab占用100M内存的话,那么这个slab下应该有100个page

3、每个page里面包含一组chunk,chunk是真正存放数据的地方,同一个slab里面的chunk的大小是固定的

4、应该可以理解为什么memcache存放的value大小是限制的,因为一个新数据过来,slab会先以page为单位申请一块内存,申请的内存最多就只有1M,所以value大小自然不能大于1M了

5、memcache的内存分配chunk里面会有内存浪费,88字节的value分配在128字节(紧接着大的用)的chunk中,就损失了30字节,但是这也避免了管理内存碎片的问题

6、memcache的LRU算法不是针对全局的,是针对slab的

总结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,因为这个操作的速度相对缓慢且会阻塞其他的操作

8、memcache设置添加某一个Key值的时候,传入expiry为0表示这个Key值永久有效,这个Key值也会在30天之后失效

数据在内存中失效后,并不会立马被删除,只有在下次get时候,系统才会将其删除。
        memcache可以因此,被一些未被及时删除的数据占满空间。
        加之LRU淘汰机制,永久数据如果很少被访问的话,在内存空间被占满的情况下,再有新数据被缓存,则永久数据,就有可能被删除

PHP的memcache客户端所有方法总结
 
 memcache::add

添加一个值,如果已经存在,则返回false

memcache::addServer

添加一个可供使用的服务器地址

memcache::close

关闭一个memcache对象

memcache::connect

创建一个memcache对象
    
memcache::decrement

对保存的某个key中的值进行减法操作
 
 memcache::delete

删除一个key值

memcache::flush

清除所有缓存的数据
    实际上没有释放资源,它仅仅将所有的缓存标记为过期,这样可以使新的缓存来覆盖被占的内存空间。

memcache::get

获取一个key值

memcache::getExtendedStats

获取进程池中所有进程的运行系统统计

memcache::getServerStatus

获取运行服务器的参数
    成功返回服务器状态,服务器没有启动会返回0,其他数字的时候表示服务器是启动状态的。

memcache::getStats

返回服务器的一些运行统计信息
 
 memcache::getVersion

返回运行的memcache的版本信息

memcache::increment

对保存的某个key中的值进行加法操作

memcache::pconnect

创建一个memcache的持久连接对象

memcache::replace

对一个已有的key进行覆写操作

memcache::set
    添加一个值,如果已经存在,则覆写

时间: 2024-08-10 05:43:09

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设计理念就是小而强大,它简单的设计促进了快速部署.易于开发并解决面对大规模的数据缓存的

运维杂记-02

################################################### 当我们系统架构出现瓶颈的时候一般扩展方法分为: 纵向扩展也可以叫垂直扩展,比如扩充服务器的cpu 1颗到2颗 内存8G到16G 磁盘容量扩容... 横向扩展也可以叫水平扩展,比如web服务器从1台,增加到2台... ###################################################负载均衡实现方法  之 http的header头    DNS轮询 http

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.