博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
存储系统设计(转)
阅读量:6046 次
发布时间:2019-06-20

本文共 643 字,大约阅读时间需要 2 分钟。

一个存储系统将每个文件存储成一系列的数据块(数据块总数不超过10w),除了最后一个,
所有的数据块都是同样大小的。比如在目录 /var/lib/chunk 存储这些块,如下:
  1. /var/lib/chunk
  2.                     /blk_0_0
  3.                    /blk_0_3
  4.                    /blk_1_7
  5.                    /...
  6.                    /blk_555_92
  7.                    /subdir0/
  8.                    /subdir1/
  9.                    /...
  10.                   /subdir63
复制代码
存储的文件以 blk_%fid_%bid 命名。但目录中的块数增加到一定规模时,该存储系统
将建一个子目录,用于保存新的数据块。目录中的块数达到64时,就新建一个子目录。
这种安排主要使每个目录中的文件数量可控。
该存储系统对外提供数据块存储、下载、删除等服务。
请用 C 语言 设计该存储系统的数据结构,以支持下列操作:
1)、根据fid、bid查找指定数据块的路径(比如 /subdir5/subdir9/blk_988_25,其中
fid = 988,bid = 25),以便存储系统提供数据块下载服务。
2)、根据fid、bid,删除指定的数据块。
3)、根据fid,删除所有指定 fid 的数据块。
4)、在满足目录限制的情况下,找到一个可用数据块存放位置,以便存储系统
提供数据块存储服务。
5)、返回该存储系统中的数据块总数以及所占空间。
限制条件;
内存: 2G
不能使用额外的磁盘空间。
如果考虑并发呢?

转载于:https://my.oschina.net/uvwxyz/blog/90014

你可能感兴趣的文章
开源 java CMS - FreeCMS2.7 登录移动端管理中心
查看>>
Android FM模块学习之三 FM手动调频
查看>>
Python 设置系统默认编码以及其他编码问题大全
查看>>
Vbs脚本编程简明教程之十四
查看>>
如何UDP/TCP端口是否通了
查看>>
pxe实现系统的自动化安装
查看>>
Redis高可用技术解决方案总结
查看>>
Scale Out Owncloud 高可用(2)
查看>>
何为敏捷
查看>>
HA集群之四:Corosync+Pacemaker+DRBD实现HA Mysql
查看>>
服务器定义
查看>>
我的友情链接
查看>>
分布式系统的面试题15
查看>>
个人代码库の创建快捷方式
查看>>
由strcat函数引发的C语言中数组和指针问题的思考
查看>>
无锁编程
查看>>
如何在loadrunner中做关联
查看>>
二叉树的六种遍历方法汇总(转)
查看>>
用wxpython制作可以用于 特征筛选gui程序
查看>>
【转载】 [你必须知道的.NET]目录导航
查看>>