- 浏览: 138694 次
文章分类
最新评论
-
wangyudong:
很有帮助的代码实例,测试Spring Boot REST AP ...
1、springboot入门案例helloworld与集成hibernate -
wangyudong:
学习了,的确是一个非常好的Spring boot实例,很快就写 ...
1、springboot入门案例helloworld与集成hibernate
memcached是高性能的分布式内存缓存服务器。
什么是Memcached
许多Web应用程序都将数据保存到RDBMS(关系型数据库)中,应用服务器从中读取数据并在浏览器中显示。但随着数据量的增大,访问的集中,就会出现RDBMS的负担加重,数据库响应恶化,网站显示延迟等重大影响。Memcached是高性能的分布式内在缓存服务器。一般的使用目的是通过缓存数据库查询结果,减少数据库的访问次数,以提高动态Web应用的速度、提高扩展性。
Memcached特点
1、协议简单:使用的是基于文本的协议。
2、基于libevent的事件处理: libevent是个程序库,他将linux的epoll、BSD类操作系统的kqueue等时间处理功能封装成统一的接口。memcached使用这个libevent库,因此能在linux、BSD等操作系统上发挥其高性能。
3、内置内存存储方式:为了提高性能,memcached中保存的数据都存储在memcached内置的内存存储空间中。由于数据仅存中,因些重启memcached,重启操作系统会导致全部数据消失。另外,内容容量达到指定的值之后memcached会自动删除不适用的缓存。
4、memcached不互通信的分布式
memcached的内存管理
最近的Memcached默认情况下采用了名为Slab Allocation.其原理----将分配的内存分割成各种尺寸的块(chunk),并把尺寸相同的块分成组(chunk的集合),每个chunk集合被称为slab。
memcached的内存分配以page为单位,page默认值为1M,可以在启动时通过-l参数来指定。
slab是由多个page组成的,pag按照指定大小切割成多个chunk。
而且slab allocation还有重复使用已分配内存的目的。即内存不会释放,而是重复利用。
Slab Allocation 的主要术语
Page :分配给Slab 的内存空间,默认是1MB。分配给Slab 之后根据slab 的大小切分成chunk.
Chunk : 用于缓存记录的内存空间。
Slab Class:特定大小的chunk 的组。
在slab中缓存记录的原理
memcached根据收到的数据的大小,选择最合适大小的slab,memcached中保存着slab内空闲chunk的列表,根据该列表选择chunk,然后将数据缓存于其中。
memcached在数据删除方面有效的利用资源
memcached删除数据时数据不会真正从memcached中消失。memcached不会释放已分配的内存。记录超时后,客户端就无法再看见该记录,其存储空间即可重复使用。
lazy expiration: memcached内部不会监视记录是否过期,而是在get时查看记录的时间戳,检查记录是否已过期。
LRU:从缓存中有效删除数据的原理
memcached会优先使用已超时的记录空间,但当空间不足时,此时会使用LRU机制来分配空间。即删除最近最少使用的记录的机制。因此当memcached的内存空间不足时(无法从slab class)获取到新空间时,就从最近未使用的记录中搜索,并将空间分配给新的记录。
memcached分布式
memcached虽然称为“分布式”缓存服务器,但服务器端并没有“分布式”的功能。memcached的分布式完全是由客户端实现的。
例如下面假设memcached服务器有node1~node3三台,应用程序要保存键名为“tokyo”“kanagawa”“chiba”“saitama”“gunma” 的数据。
首先向memcached中添加“tokyo”。将“tokyo”传给客户端程序库后,客户端实现的算法就会根据“键”来决定保存数据的memcached服务器。服务器选定后,即命令它保存“tokyo”及其值。
同样,“kanagawa”“chiba”“saitama”“gunma”都是先选择服务器再保存。
接下来获取保存的数据。获取时也要将要获取的键“tokyo”传递给函数库。函数库通过与数据保存时相同的算法,根据“键”选择服务器。使用的算法相同,就能选中与保存时相同的服务器,然后发送get命令。只要数据没有因为某些原因被删除,就能获得保存的值。
这样,将不同的键保存到不同的服务器上,就实现了memcached的分布式。 memcached服务器增多后,键就会分散,即使一台memcached服务器发生故障无法连接,也不会影响其他的缓存,系统依然能继续运行。
memcached简单示例
引入spymemcached-2.11.4.jar依赖包,安装并启动memcached
安装文件与依赖包见附件
什么是Memcached
许多Web应用程序都将数据保存到RDBMS(关系型数据库)中,应用服务器从中读取数据并在浏览器中显示。但随着数据量的增大,访问的集中,就会出现RDBMS的负担加重,数据库响应恶化,网站显示延迟等重大影响。Memcached是高性能的分布式内在缓存服务器。一般的使用目的是通过缓存数据库查询结果,减少数据库的访问次数,以提高动态Web应用的速度、提高扩展性。
Memcached特点
1、协议简单:使用的是基于文本的协议。
2、基于libevent的事件处理: libevent是个程序库,他将linux的epoll、BSD类操作系统的kqueue等时间处理功能封装成统一的接口。memcached使用这个libevent库,因此能在linux、BSD等操作系统上发挥其高性能。
3、内置内存存储方式:为了提高性能,memcached中保存的数据都存储在memcached内置的内存存储空间中。由于数据仅存中,因些重启memcached,重启操作系统会导致全部数据消失。另外,内容容量达到指定的值之后memcached会自动删除不适用的缓存。
4、memcached不互通信的分布式
memcached的内存管理
最近的Memcached默认情况下采用了名为Slab Allocation.其原理----将分配的内存分割成各种尺寸的块(chunk),并把尺寸相同的块分成组(chunk的集合),每个chunk集合被称为slab。
memcached的内存分配以page为单位,page默认值为1M,可以在启动时通过-l参数来指定。
slab是由多个page组成的,pag按照指定大小切割成多个chunk。
而且slab allocation还有重复使用已分配内存的目的。即内存不会释放,而是重复利用。
Slab Allocation 的主要术语
Page :分配给Slab 的内存空间,默认是1MB。分配给Slab 之后根据slab 的大小切分成chunk.
Chunk : 用于缓存记录的内存空间。
Slab Class:特定大小的chunk 的组。
在slab中缓存记录的原理
memcached根据收到的数据的大小,选择最合适大小的slab,memcached中保存着slab内空闲chunk的列表,根据该列表选择chunk,然后将数据缓存于其中。
memcached在数据删除方面有效的利用资源
memcached删除数据时数据不会真正从memcached中消失。memcached不会释放已分配的内存。记录超时后,客户端就无法再看见该记录,其存储空间即可重复使用。
lazy expiration: memcached内部不会监视记录是否过期,而是在get时查看记录的时间戳,检查记录是否已过期。
LRU:从缓存中有效删除数据的原理
memcached会优先使用已超时的记录空间,但当空间不足时,此时会使用LRU机制来分配空间。即删除最近最少使用的记录的机制。因此当memcached的内存空间不足时(无法从slab class)获取到新空间时,就从最近未使用的记录中搜索,并将空间分配给新的记录。
memcached分布式
memcached虽然称为“分布式”缓存服务器,但服务器端并没有“分布式”的功能。memcached的分布式完全是由客户端实现的。
例如下面假设memcached服务器有node1~node3三台,应用程序要保存键名为“tokyo”“kanagawa”“chiba”“saitama”“gunma” 的数据。
首先向memcached中添加“tokyo”。将“tokyo”传给客户端程序库后,客户端实现的算法就会根据“键”来决定保存数据的memcached服务器。服务器选定后,即命令它保存“tokyo”及其值。
同样,“kanagawa”“chiba”“saitama”“gunma”都是先选择服务器再保存。
接下来获取保存的数据。获取时也要将要获取的键“tokyo”传递给函数库。函数库通过与数据保存时相同的算法,根据“键”选择服务器。使用的算法相同,就能选中与保存时相同的服务器,然后发送get命令。只要数据没有因为某些原因被删除,就能获得保存的值。
这样,将不同的键保存到不同的服务器上,就实现了memcached的分布式。 memcached服务器增多后,键就会分散,即使一台memcached服务器发生故障无法连接,也不会影响其他的缓存,系统依然能继续运行。
memcached简单示例
引入spymemcached-2.11.4.jar依赖包,安装并启动memcached
安装文件与依赖包见附件
package com.test1; import java.io.IOException; import java.net.InetSocketAddress; import net.spy.memcached.CASValue; import net.spy.memcached.MemcachedClient; public class Demo1 { public static void main(String[] args) throws IOException { // Connecting to Memcached server on localhost MemcachedClient mcc = new MemcachedClient(new InetSocketAddress( "127.0.0.1", 11211)); System.out.println("Connection to server sucessfully"); // not set data into memcached server //System.out.println("set status:"+ mcc.set("su", 900, "memcached")); // Get value from cache //mcc.set("shu", 3, "su"); /*System.out.println("Get from Cache:" + mcc.get("yiibai")); System.out.println(mcc.get("ya")); CASValue x1= mcc.gets("yiibai"); System.out.println(x1.getCas()+"--"+x1.getValue()); */ //System.out.println(mcc.add("key1", 30,"chentian").getStatus()); //mcc.add("key1", 900, "5"); System.out.println(mcc.gets("key1").getCas()+" "+mcc.get("key1")); //mcc.replace("key1", 30, "fs"); //替换 //mcc.append("key1", "fsdaf"); //在后面添加 //mcc.prepend("key1", "ssssssss"); //在前面添加 //mcc.delete("key1"); //删除 //mcc.cas("key1", mcc.gets("key1").getCas(), "cf"); //mcc.incr("key1", 2); //递增 System.out.println(mcc.gets("key1").getCas()+" "+mcc.get("key1")); //mcc.decr("key1", 1); //递减 mcc.flush(); //清除 System.out.println(mcc.gets("key1").getCas()+" "+mcc.get("key1")); System.out.println(mcc.getStats()); } }
- memcached_en32or64.zip (202 KB)
- 下载次数: 1
- spymemcached-2.11.4.jar (453.9 KB)
- 下载次数: 0
发表评论
-
tomcat学习一(简单web服务器示例)
2016-09-20 17:14 487Request.java package com.chen ... -
8、在docker上部署简单javaweb应用
2016-04-24 19:12 8971、创建容器javaweb1,并添加数据卷便于将安装文件共享到 ... -
7、Docker容器的数据管理
2016-04-24 17:56 1159一、Docker容器的数据卷 ... -
6、Docker容器的网络连接
2016-04-24 17:54 1718一、Docker容器的网络基础 dock ... -
4、Docker镜像
2016-04-22 09:05 845一、什么是Docker镜像 ... -
5、Docker客户端和守护进程
2016-04-22 09:04 1019一、Docker的C/S模式 ... -
3、Docker容器常用命令与在容器中部署静态网站
2016-04-22 09:04 900一、容器的基本操作 ... -
2、Docker简介及docker组成部分
2016-04-22 09:03 17881、Docker提供了一个容器 ... -
1、Ubuntu14.04安装docker
2016-04-22 09:02 706一、安装前检查 1、内核版本 uname - ... -
6、java连接redis集群
2016-04-18 18:26 26451、使用Jedis 连接集群会报 MOVED错误 packag ... -
redis集群搭建
2016-04-18 16:15 593redis-cli -h 127.0.0.1 -p 6749 ... -
ubuntu14.04卸载redis并手动安装redis-3.0
2016-04-18 16:14 11561、ubuntu 卸载redis 1)卸载软件 ... -
redis五种数据类型常用基本命令总结
2016-04-14 19:00 759redis-cli 启动redis客户端,连接到redis服务 ... -
java连接远程服务器redis常遇问题
2016-04-14 18:58 32551、先在本地CMD命令中ping IP地址,网络是否正常 2、 ... -
redis虚拟机环境搭建与安装redis
2016-04-12 09:14 1785下载VMware 下载ubuntu14.iso 在VMware ... -
dubbo入门案例
2016-04-07 19:47 1221windows安装zookeeper 把下载的zookeepe ... -
webservice cxf简单案例
2016-03-30 18:44 701cxf简单java项目案例 IHelloWorld.java ... -
spring mvc教程视频
2016-01-18 17:29 8151. 韩顺平 Spring视频教程 http://www.yu ... -
Redis与Memcached比较
2016-01-13 11:01 821作为内存数据缓冲 ... -
Redis原理与简述
2016-01-13 10:46 12680Redis是一个开源的key-value存储系统。 ...
相关推荐
4. 简述Memcached内存管理机制原理? Memcached使用slab allocation机制来管理内存,每个slab分配一个固定的内存大小,用于存储对象。 5. Memcached是怎么工作的? Memcached服务器可以接受客户端的请求,检查缓存...
Memcached和Redis简述** Memcached是一款轻量级的内存键值对存储系统,它设计用于快速存储临时数据。而Redis则更加强大,除了键值对存储外,还支持多种数据结构,如字符串、哈希、列表、集合和有序集合。它们都通过...
- **前言**:简述了memcached的重要性以及在项目中的应用背景。 - **缓存对象与使用session的区别**:对比了两种不同的缓存方式,帮助开发者选择合适的方案。 #### 二、XCache:加速PHP **XCache** 是一个高性能的...
书籍1:互联网 Java 工程师面试题 内容涵盖:Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、 ...27、简述 Mybatis 的插件运行原理,以及如何编写一个插件 等等 书籍2:JAVA核心知识整理
简述 昨天support一同事,帮她的客户做类似下面的效果(自动完成): 以前在搜房的时候,弄过这个,调用楼盘字典: 这是一个小功能,也是一个大功能。因为它可以做大,也可以做小。二.搜房的AutoComplete 比如上面...
**六、缓存原理** Django的缓存机制基于键值对(Key-Value Store),它会根据指定的键(key)存储和检索数据。当数据被设置到缓存中时,Django会根据过期时间来决定何时删除该数据。如果请求的数据不在缓存中,...
#### 二十二、简述JVM的工作原理? - **JVM**: JVM(Java虚拟机)是Java程序的运行环境。它负责将Java字节码转换成特定平台的机器指令,提供了内存管理和垃圾回收机制等。 以上问题涵盖了Java及其相关框架的基础...
...............................................................................4319、简述 MyBatis 的一级缓存和二级缓存,以及它们的区别和工作原理。.........................................................
1. PHP框架:简述常见的PHP框架,如Laravel、Symfony、CodeIgniter等,及其特点和用途。 2. Composer依赖管理:掌握使用Composer安装、更新和管理PHP项目的依赖。 3. PHP扩展:理解PHP扩展的作用,如安装、配置和...
3. CSRF跨站请求伪造:理解CSRF攻击原理,学习防止CSRF的方法,如使用令牌验证。 六、PHP框架 1. Laravel:讲解Laravel框架的基础概念,路由、控制器、视图、模型、数据库迁移、Artisan命令行工具等。 2. ThinkPHP...
- **Memcached**:使用内存缓存系统,速度快,但数据非持久化,服务器重启后数据丢失。 - **Cookie**:客户端存储,数据大小有限,安全性较低,适用于小型应用或用户端状态管理。 9. **HTTP状态码及其处理**: -...
1. **HTTP协议**:了解HTTP请求和响应的基本原理,以及PHP如何处理这些请求。 2. **表单处理**:学会使用`$_GET`和`$_POST`来获取表单数据,并进行验证和过滤。 3. **URL操作**:解析和构建URL,使用`$_SERVER`全局...