目录

. 缓存机制简介
. 内核缓存机制
. 内存缓存机制
. 文件缓存机制
. 数据库缓存机制

1. 缓存机制简介

0x1: 什么是缓存cache

在计算机整个领域中,缓存(cache)这个词是一个庞大的概念,总体上来说,缓存是一种处理方式的统称,缓存通过预取将经常要用到的东西(常常是多人公用)通过一个集中公用的地方进行临时保存,并通过一定的算法对其进行管理,从而显著提高资源使用方的运行效率

0x2: 缓存的分类

缓存的分类有很多,根据所处层次、存储位置的不同,我们可以如下分类

. 内核缓存机制
这是Linux系统在内核态实现的高速缓存机制,内核缓存机制是在linux的内核代码中实现的
http://www.penglixun.com/tech/system/linux_cache_discovery.html
) ./fs/fscache/cache.c: Cache实现的代码
) ./mm/slab.c: SLAB管理器代码
) ./mm/swap.c: 缓存替换算法代码
) ./mm/mmap.c: 内存管理器代码
) ./mm/mempool.c: 内存池实现代码 . 内存缓存机制
通过将热点数据临时保存在系统的一段连续空间中,并使用相应的数据结构和API进行操作管理
) C言语实现的哈希表: uthash: http://troydhanson.github.io/uthash/
) Java、C#实现的缓存库函数(本质也是框架自己在内存中实现了一套缓存数据结构、API) . 文件缓存机制
) 文件虚拟映射技术: 将磁盘上的文件映射到内存中,此后就可以想读写内存一样读写文件
) 缓存数据序列化保存技术: 典型的像PHP Session会将会话数据通过serialize后缓存在文件中,在任何需要的时候进行IO读写
) 将待缓存数据直接保存到磁盘文件中: 典型的像Discuz、dedeCMS会将配置文件、session信息、公用数据通过文件的方式缓存到磁盘上,在需要的时候再通过inlcude方式包含进来 . 数据库缓存机制
当需要保存的缓存数据较大时,就需要使用到数据库缓存机制,现有的数据库缓存方案主要可以分为2大类
4.1 基于内存cache的数据库缓存,定时写文件
) libmemcached: libmemcached
) Alternative PHP Cache (APC): http://pecl.php.net/package/APC
4.2 基于关系型数据库数据缓存
) FastDHT: http://sourceforge.net/projects/fastdht/
4.3 基于非关系型(NoSQL)数据库缓存(key-value)
) Tokyo Cabinet: http://fallabs.com/tokyocabinet/
) Flare: http://labs.gree.jp/blog/
) ThruDB: https://code.google.com/p/thrudb/
) 淘宝tair: http://www.infoq.com/cn/articles/taobao-tair/
) redis: http://www.redis.io/

0x3: 缓存Cache的应用场景

除了缓解CPU密集型计算带来的时间损耗,而将计算结果缓存在cache中这种应用场景之外,在很多情况下,Cache机制(或者说Cache思想)会被应用在跨系统、跨模块通信中,两边的通信速度不匹配,即消费能力和生产能力不匹配,而cache就是有效缓解和平衡这个速度差异的一个很好的技术思想,通过cache将原本因为速度差异导致的串行阻塞转化为了异步的非等待通信方式。根据两边的速度差异,cache有不同的调控策略

. A_Speed < B_Speed

. A_Data_Amount(单次发送的数据量) < B_Data_Amount
这种情况下,A系统会向B系统发送大量的"零碎包",如果B系统是Hadoop系统,则会造成分析效率地下。为了解决这个问题,需要在A系统的流量出口部署Cache模块,进行"组包操作"
) 组包(增大单包容量)
if(sizeof(cache_array[]) < max_value)
{
继续cache;
}
else
{
立即发送
reset 计时器;
}
) 延时自动发送
if(本次cache计时器时间 < max_time)
{
continue;
}
else
{
立即发送
reset 计时器;
} . A_Speed > B_Speed
这种情况下,A系统的数据产生和发送速度远大于B系统,很容易造成DDOS攻击现象,为了解决这个问题,需要在A系统的流量出口部署"阈值流量控制模块",防止突然出现的大量数据造成峰值流量
在实施方案的时候,需要考虑是否存在小包现象,如果存在则需要引入组包机制
) 切包(控制发包速度)
if(sizeof(JSON_CACHE) > cli_json_cache_maxvalue)
{
发送 JSON_CACHE[~cli_json_cache_maxvalue];
清空 JSON_CACHE[~cli_json_cache_maxvalue];
}
else
{
直接发送
} . A_Data_Amount(单次发送的数据量) > B_Data_Amount

2. 内核缓存机制

待梳理

Relevant Link:


3. 内存缓存机制

0x1: C uthash

uthash是一款基于C语言实现的内存Hash缓存类库,它的核心思想是HASH表技术,通过将值与其存储位置相关联,来实现快速的随机存储

uthash是一个C语言的hash表实现。它以宏定义的方式实现hash表,可以让程序员非常方便的使用待缓存功能的HASH表
1. uthash支持的操作

. 增加
. 查找
. 删除
. 计数
. 迭代
. 排序
. 选择等操作

2. uthash支持的hash函数

. OAT One-at-a-time
. Symbol Name
. JEN Jenkins (default)
. BER Bernstein
. SAX Shift-Add-Xor
. FNV Fowler/Noll/Vo
. SFH Paul Hsieh
. MUR MurmurHash
//编译代码时,可以选择不同的hash函数,只要在编译时指定就可以了
cc -DHASH_FUNCTION=HASH_BER -o program program.c

3. uthash进行缓存开发的大致步骤

. 包含头文件
#include "uthash.h" . 自定义数据结构
) 每个结构代表一个键-值对
) 每个结构中要有一个UT_hash_handle成员(类似内核中在结构中加入list_head使之成为双链表的原理)
struct my_struct
{
int id; /* key */
char name[];
UT_hash_handle hh; /* makes this structure hashable */
}; . 定义hash表指针。这个指针为前面自定义数据结构的指针,并初始化为NULL
/* important! initialize to NULL */
struct my_struct *users = NULL; . 建立hash表(插入新元素)
int add_user(int user_id, char *name)
{
struct my_struct *s;
s = malloc(sizeof(struct my_struct));
s->id = user_id;
strcpy(s->name, name);
/*
users: the hash table pointer that you will insert
id: name of key field
s: the value of key that you will insert
*/
HASH_ADD_INT( users, id, s );
} . 查找
struct my_struct *find_user(int user_id)
{
struct my_struct *s;
HASH_FIND_INT( users, &user_id, s ); /* s: output pointer */
return s;
} . 删除
void delete_user(struct my_struct *user)
{
HASH_DEL( users, user); /* user: pointer of hash item to deletee */
free(user); /* optional; it’s up to you! */
} . 计数
unsigned int num_users;
num_users = HASH_COUNT(users);
printf("there are %u users/n", num_users); . 迭代
void print_users()
{
struct my_struct *s;
for(s = users; s != NULL; s=s->hh.next)
{
printf("user id %d: name %s/n", s->id, s->name
}
} . 排序
int name_sort(struct my_struct *a, struct my_struct *b)
{
return strcmp(a->name,b->name);
}
int id_sort(struct my_struct *a, struct my_struct *b)
{
return (a->id - b->id);
}
void sort_by_name()
{
HASH_SORT(users, name_sort);
}
void sort_by_id()
{
HASH_SORT(users, id_sort);
}

4. uthash编程实例

#include "uthash.h"
#include <stdlib.h> /* malloc */
#include <stdio.h> /* printf */ typedef struct example_user_t
{
int id;
int cookie;
UT_hash_handle hh;
} example_user_t; int main(int argc,char *argv[])
{
int i;
example_user_t *user, *users=NULL; /* create elements */
for(i=;i<;i++)
{
if ( (user = (example_user_t*)malloc(sizeof(example_user_t))) == NULL) exit(-);
user->id = i;
user->cookie = i*i;
HASH_ADD_INT(users,id,user);
} for(user=users; user != NULL; user=(example_user_t*)(user->hh.next))
{
printf("user %d, cookie %d\n", user->id, user->cookie);
}
return ;
}

aaarticlea/png;base64,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" alt="" />

更多example,请参阅

https://github.com/troydhanson/uthash/archive/master.zip

Relevant Link:

http://www.cnblogs.com/haippy/archive/2012/01/12/2315532.html
http://shentar.me/%E5%9F%BA%E4%BA%8Ec%E8%AF%AD%E8%A8%80%E7%9A%84hash-table%E5%AE%9E%E7%8E%B0%E8%BF%9B%E7%A8%8B%E5%86%85%E7%BC%93%E5%AD%98/
http://troydhanson.github.io/uthash/
http://blog.csdn.net/hongqun/article/details/6103275
http://zh.wikipedia.org/zh-cn/%E5%93%88%E5%B8%8C%E8%A1%A8
http://en.wikipedia.org/wiki/Hash_table


4. 文件缓存机制

待梳理

Relevant Link:


5. 数据库缓存机制

待梳理

Relevant Link:

Copyright (c) 2014 LittleHann All rights reserved

Linux Cache Mechanism Summary(undone)的更多相关文章

  1. 【转载】Linux Cache Mechanism Summary(undone)

    http://www.cnblogs.com/LittleHann/p/3904909.html 目录 1. 缓存机制简介 2. 内核缓存机制 3. 内存缓存机制 4. 文件缓存机制 5. 数据库缓存 ...

  2. Linux cache释放

    cache释放: To free pagecache: > /proc/sys/vm/drop_caches To free dentries and inodes: > /proc/sy ...

  3. Linux cache 缓存过大

    linux cache 缓存过大 : 除重启服务 之外:直接释放内存方式之一: 修改配置释放cached内存: echo > /proc/sys/vm/drop_caches

  4. Linux Cache 机制

    在阅读文章前,您应该具备基本的存储器层次结构知识,至少要了解局部性原理.要详细了解cache基本原理,可以参考本书<深入理解计算机系统>中存储器体系结构一章: 带着疑问来看文章,cache ...

  5. Linux File、File Directory IO Operation Summary(undone)

    目录 . 引言 . Linux下文件操作API . Linux下文件目录操作API . Linux下的其他设备操作API 1. 引言 Linux支持多种文件系统,如ext.ext2.minix.iso ...

  6. Linux Communication Mechanism Summarize

    目录 . Linux通信机制分类简介 . 控制机制 0x1: 竞态条件 0x2: 临界区 . Inter-Process Communication (IPC) mechanisms: 进程间通信机制 ...

  7. linux cache and buffer【转】

    转自:http://blog.csdn.net/turkeyzhou/article/details/6426738 版权声明:本文为博主原创文章,未经博主允许不得转载. Linux下对文件的访问和设 ...

  8. linux cache swap 以及 虚拟内存等

    提出四个问题及解答: 1)若进程在运行过程中,物理内存不足会发生什么? 2)为何进程在占用物理内存不变的情况下,系统的物理内存会增加? 3)为何程序的大小大于实际占用的物理内存?(假如程序30M,却只 ...

  9. Free命令详解和释放linux Cache(转载)

    因为LINUX的内核机制,一般情况下不需要特意去释放已经使用的cache.这些cache起来的内容可以增加文件以及的读写速度. 先说下free命令怎么看内存 [root@yuyii proc]# fr ...

随机推荐

  1. 转:程序员必须知道的几个Git代码托管平台

    http://www.open-open.com/lib/view/open1420704561390.html

  2. R语言-merge和rbind

    rbind 使用方式 合并两个数据集,要求两个数据集的列数相等: rbind(parameter1,parameter2) 1 1 合并多个数据集,各个数据集的列数相等: rbind(paramete ...

  3. ios开发中如何隐藏各种bar

    转载自http://www.cnblogs.com/lovecode/articles/2234557.html 状态条Status Bar [UIApplication sharedApplicat ...

  4. 九、Foundation框架中的NSString常用方法

    一.NSString的创建 方式1创建常量字符串 NSString *st = @"this is string!"; //这种方式创建的字符串不需要释放 方式2创建空字符串,给予 ...

  5. 教你10分钟内在Windows上完成Rails开发环境的安装和配置

    原文:http://www.cnblogs.com/tambor/archive/2011/12/25/rails_anzhuang_railsinstaller.html 一般来说,Windows开 ...

  6. VS2010引用App_Code下的类文件问题解决方法

    原文连接:http://blog.csdn.net/zjlovety/article/details/7658528 VS2020中“添加ASP.NET文件夹”里没有App_Code,添加普通文件夹然 ...

  7. Android中的IMEI

    国际移动设备识别码(IMEI:International Mobile Equipment Identification Number)是区别移动设备的标志,储存在移动设备中,可用于监控被窃或无效的移 ...

  8. 在Sql Server 中使用正则表达式

    CREATE FUNCTION dbo.find_regular_expression ( ), --需要匹配的源字符串 ), --正则表达式 --是否区分大小写,默认为false ) RETURNS ...

  9. 本地RUN页面时候,将异常直接显示出来,而不是乱码

    本地运行页面时,经常会遇到以下错误 oracle.jbo.JboException: JBO-29000: JBO-29000: JBO-26028: ???? MemberAttributesDis ...

  10. HttpClient, 使用C#操作Web

    我们知道, .Net类库里提供了HttpWebRequest等类,方便我们编程与Web服务器进行交互. 但是实际使用中我们经常会遇到以下需求,基础类里没有直接提供相应的功能(WebClient类包含这 ...