vdisk 的缓存系统设计

<!-- /* 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 也是不需要的。

 

### 回答1: vdisk 是一种基于云计算的虚拟磁盘服务,用户可以在其中存储和分享自己的文件和数据。在新疆这个地区,vdisk 也是被广泛应用的一种工具。 shp 是一种常见的矢量数据格式,其文件扩展名为 .shp。这种格式通常用于存储地理信息系统(GIS)中的空间数据,包括点、线和面等要素。可以通过各种软件工具来打开和处理 shp 格式的数据。 在新疆地区,使用 shp 格式的数据也比较常见。比如,可以用 shp 格式来存储矢量地图数据、行政区划数据等等。通过将这些数据上传到 vdisk 上,用户可以实现在线共享和协作,也可以方便地和其他系统进行数据交换。 总的来说,vdisk 和 shp 都是地理信息系统中比较常见的工具和格式,它们在新疆地区的应用也比较广泛。通过将这两者结合起来,可以更好地实现数据的存储、分享和协作。 ### 回答2: Vdisk是一种云存储服务,在这个服务中,用户可以将自己的文件上传到云端并保护它们,确保文件的安全和可靠性。而新疆是中国西北部的一个省份,地形复杂,历史悠久,有着独特的文化底蕴和自然景观。矢量是一种地图数据类型,通过将地图信息切割成各种形状的几何体来构建图像。而Shp是一种用来存储矢量地图数据的格式。因此,vdisk 新疆矢量 shp就是指使用vdisk技术将新疆省的矢量地图数据以shp格式进行存储。这样可以方便地让用户在任何时间和地点都可以访问这些地图数据,而不必担心数据的丢失或损坏。总之,vdisk 新疆矢量 shp是现代科技的最新成果,使用户能够更好地管理和利用新疆省的矢量地图数据,带来更加便捷和高效的数据处理体验。 ### 回答3: VDisk是一种云存储服务平台,能够帮助用户存储和管理各种类型的文件。而新疆是我国的一个省份,位于中国西北边陲地带,具有非常丰富的资源和特殊的地理环境。而SHK则是一种地理信息系统所采用的数据格式,它能够储存各种空间数据和属性信息。 因此,"VDisk 新疆 矢量 shp"的意思就是在VDisk平台上,存储和管理着新疆省的空间数据,这些数据采用了shp格式,并且其中包含了丰富的矢量信息。这些数据可能包括新疆省的地理位置、地形地貌、边界、交通网络、资源分布等等,并且可以通过地理信息系统的工具进行分析和处理。 这种数据的存储和管理,可以为地理信息系统的应用提供丰富的数据来源和基础支撑,同时也为各种研究和决策提供了可靠依据。通过VDisk平台,用户可以方便地上传和下载这些数据,并且进行共享和协同编辑。因此,"VDisk 新疆 矢量 shp"代表着一种优秀的信息资源,可以为地理信息系统的应用提供质量和效率的保障。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值