<!-- /* Font Definitions */ @font-face {font-family:宋体; panose-1:2 1 6 0 3 1 1 1 1 1; mso-font-alt:SimSun; mso-font-charset:134; mso-generic-font-family:auto; mso-font-pitch:variable; mso-font-signature:3 135135232 16 0 262145 0;} @font-face {font-family:"/@宋体"; panose-1:2 1 6 0 3 1 1 1 1 1; mso-font-charset:134; mso-generic-font-family:auto; mso-font-pitch:variable; mso-font-signature:3 135135232 16 0 262145 0;} /* Style Definitions */ p.MsoNormal, li.MsoNormal, div.MsoNormal {mso-style-parent:""; margin:0cm; margin-bottom:.0001pt; text-align:justify; text-justify:inter-ideograph; mso-pagination:none; font-size:10.5pt; mso-bidi-font-size:12.0pt; font-family:"Times New Roman"; mso-fareast-font-family:宋体; mso-font-kerning:1.0pt;} span.EmailStyle15 {mso-style-type:personal; mso-style-noshow:yes; mso-ansi-font-size:9.0pt; mso-bidi-font-size:10.0pt; font-family:Arial; mso-ascii-font-family:Arial; mso-fareast-font-family:宋体; mso-hansi-font-family:Arial; mso-bidi-font-family:Arial; color:windowtext;} /* Page Definitions */ @page {mso-page-border-surround-header:no; mso-page-border-surround-footer:no;} @page Section1 {size:595.3pt 841.9pt; margin:72.0pt 90.0pt 72.0pt 90.0pt; mso-header-margin:42.55pt; mso-footer-margin:49.6pt; mso-paper-source:0; layout-grid:15.6pt;} div.Section1 {page:Section1;} /* List Definitions */ @list l0 {mso-list-id:496922159; mso-list-type:hybrid; mso-list-template-ids:2038564230 1768743268 67698713 67698715 67698703 67698713 67698715 67698703 67698713 67698715;} @list l0:level1 {mso-level-tab-stop:18.0pt; mso-level-number-position:left; margin-left:18.0pt; text-indent:-18.0pt;} ol {margin-bottom:0cm;} ul {margin-bottom:0cm;} -->

Linux 缓存系统设计:

1.       首先在系统启动的时候分配 256MB 的大小。并按照 16KB+header 建立 free list.

2.       为每个 Vdisk 维护一个二叉树,此二叉树是以 header->start_sect 排序。

3.       维护一个二叉堆用来管理应经使用的 buffer. 并切维护一个全局变量计数,最近使用的, header->id = gcnt, gcnt++.

这样,当访问 vdisk 的时候,首先从 vdisk->avl tree ,使用 start sect 去查找,如果找到,更新 header->id, 如果 gcnt 的值最高 4 位全为 1 时,则清空 usedbuffer 二叉堆得高 16 位。

更新 usedbuffer 二叉堆的排序。

如果不在 vdisk 的二叉树中, 判断 freelist, 如果 freelist 不为空,则从 freelist 中取下,取得数据,写入到缓冲区,更新 header->id

然后插入到 vdisk 的二叉树中,插入到 usedbuffer 的二叉堆中

如果 freelist 为空,则从 used 二叉堆中删除第一个最不常用的 , 从某个 vdisk 上删除 buffer ,考虑是否要回写。

更新 header->id, copy 数据,插入到 vdisk->avl tree ,更新 usedbuffer 二叉堆。

Header 应该有以下成员:

dirty

diskno:

start_sect:

last_time

LIST_ENTRY   usedlist;

LIST_ENTRY  freelist;

Freelist 需要加锁

usedbuffer 二叉堆需要锁

每个 vdisk->avl 需要锁

二叉树用 start sect 排序, usedbuf 用 last_time 排序,这样就可以做到 LRU 的算法。访问时间用该是

更改用线性列表取代 usedbuffer 二叉堆,也是可以的。 Cnt 也是不需要的。

vdisk 的缓存系统设计相关推荐

  1. 同程旅游缓存系统设计:如何打造Redis时代的完美体系(含PPT)

    导读:高可用架构 7 月 30 日在上海举办了『互联网架构的基石』专题沙龙,进行了闭门私董会研讨及对外开放的四个专题的演讲,期望能促进业界对互联网基础服务及工具的讨论,本文是王晓波分享同程旅游缓存系统 ...

  2. 基于 DDR3 的串口传图帧缓存系统设计实现(整体设计)

    文章目录 前言 一.串口传图顶层系统设计框图 二.各模块说明 三.系统工程及 IP 创建 四.uart_ddr3_tft模块 五.uart_ddr3_tft模块仿真文件 六.传图展示 前言 结合串口接 ...

  3. 基于 DDR3 的串口传图帧缓存系统设计实现(fifo2mig_axi )

    文章目录 前言 一.接口转换模块设计 二.fifo2mig_axi 模块 二.接口转换模块仿真 四.fifo2mig_axi_tb 五.仿真展示 前言 结合串口接收模块和 tft 显示屏控制模块,设计 ...

  4. 基于DDR3的串口传图帧缓存系统设计实现

    整体设计框图如图所示 模块名称 模块功能 uart_byte_rx模块 负责串口图像数据的接收 bit8_trans_bit16模块 将串口接收的每两个 8bit 数据转换成一个 16bit 数据(图 ...

  5. 无码系列-6 数据缓存设计经验谈

    1.    缓存系统概述 1.1.  数据缓存的常识 u 为了解决什么问题 水平扩展:通常数据源站专注于数据存储, 对于负载能力.性能瓶颈不会做复杂的设计.缓存系统用于避免系统性能瓶颈,实现水平扩展. ...

  6. 广域虚拟数据空间中边缘缓存系统的研究与实现

    点击上方蓝字关注我们 广域虚拟数据空间中边缘缓存系统的研究与实现 霍建同1,2, 肖利民1,2, 霍志胜1,2, 徐耀文1,2 1 软件开发环境国家重点实验室,北京 100191 2 北京航空航天大学 ...

  7. 图解|高性能服务器设计之缓存系统一致性

    缓存系统交互 缓存系统设计是后端开发人员的必备技能,也是实现高并发的重要武器. 对于读多写少的场景,我们通常使用内存型数据库作为缓存,关系型数据库作为主存储,从而形成两层相互依赖的存储体系. 共识:我 ...

  8. 一个Java程序员应该掌握的10项技能

    1.语法:必须比较熟悉,在写代码的时候IDE的编辑器对某一行报错应该能够根据报错信息知道是什么样的语法错误并且知道任何修正. 2.命令:必须熟悉JDK带的一些常用命令及其常用选项,命令至少需要熟悉:a ...

  9. 【转】一个Java程序员应该掌握的10项技能

      1.语法:必须比较熟悉,在写代码的时候IDE的编辑器对某一行报错应该能够根据报错信息知道是什么样的语法错误并且知道任何修正.   2.命令:必须熟悉JDK带的一些常用命令及其常用选项,命令至少需要 ...

最新文章

  1. 如何写一篇不水的机器学习论文?这17页指南从建模、评估到写报告,手把手教你...
  2. .net core上 K8S(七).netcore程序的服务发现
  3. 机器学习笔记:Overview
  4. win7怎么进入安全模式_windows 10如何进入安全模式
  5. php 权限规范,项目人员权限验证
  6. golang 关闭gc 并手动gc_Golang 防内存泄漏编码原则
  7. 【EhCache】Java缓存框架使用EhCache结合Spring AOP
  8. C++函数指针和仿函数【转】
  9. C# 中使用反射的优缺点
  10. java 手势识别_【人体分析-手势识别】-Java示例代码
  11. PAT C语言 1031 查验身份证 (15 分) 一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:
  12. Python 批量爬取猫咪图片实现千图成像
  13. 计算机 人脑 发热 ppt,人脑即电脑,疯狂的大脑进化史,大脑科学的革命
  14. sql 数据存在包含关系的查询
  15. 带exp在线计算机计算器使用,电脑系统自带科学计算器使用方法
  16. 计算机室在初中英语教学中的应用,信息技术在初中英语教学中的应用探析
  17. 图书馆管理系统代码html语言,html图书管理系统
  18. MATLAB聚类分析(Cluster Analysis)
  19. 清华大学刘知远:知识指导的自然语言处理
  20. 2020最全面试题库

热门文章

  1. CRT工具日常上传下载
  2. mysql导出PDM文件
  3. IT培训机构出来的学生之我见闻
  4. android怎样生成固定的aes密钥,关于android:如何更改AES 128的密钥数量
  5. vue @click 多次触发解决
  6. python序列解包_python中解包
  7. JavaScript的内存作用域闭包
  8. 树莓派如何终端手动配网
  9. (附源码)计算机毕业设计ssm房地产销售系统
  10. CHM格式文件无法打开的解决方法。