Chapter3-作業系統-磁碟管理-part1
Jul 2, 2021
3.9 磁碟管理 (Disk Management)
目錄
- Free space management
- Link list
- Combination
- Counting
- Allocation Method (配置方法)
- 連續性配置 (contiguous allocation)
- 鏈結式配置 (linked allocation)
- FAT (file allocation table)
- 索引配置 (index allocation)
- Disk structure
- Disk access time
- Disk scheduling
- FCFS
- SSTF
- SCAN
- C-SCAN
- LOOK
- C-LOOK
- 補充
- RAID
- RAID 的種類
- RAID1
- RAID0+1
- RAID2
- RAID3 vs RAID4
- RAID5
- RAID6
- Summary
Free Space Management
- Bit Vector (位元向量)
- 圖:
data:image/s3,"s3://crabby-images/54b5b/54b5badcd0f9176b873cbd42e628bd2d43db4261" alt=""
- Def: 給各 block 一個 bit, 當 bit
- bit = 0, 則 free block
- bit = 1, 則 use
- Ex:
011001110001
- 優點:
- easy to implement
- 找連續可用的 block 容易
- 缺點:當 block 太多, 則 bit vector 不適用
- Link list (鏈結串列)
- Def: 將 free block 以 link 方式串接
- Ex:
data:image/s3,"s3://crabby-images/5e576/5e5767a2a5703976113824514eb2c5f140ce6e8f" alt=""
- 優點:insert / delete free block 容易
- 缺點:
- 檔案配置不便
- link broken, data lose
- Combination (組合)
- Def: 將一 Node 給予多個格子合併而成
data:image/s3,"s3://crabby-images/b4942/b49426eca65e4ddfba8c551dc838a54e18f811c1" alt=""
- Ex:
data:image/s3,"s3://crabby-images/6f728/6f728558d22b76b9ac6483afa7bb424d1aac842e" alt=""
- Counting (計數法)
- Def: 在 linked list 中 Node 加入一空間, 放連續 free block 之數量 (連續的 free block 越多, 串列越短)
- Ex:
data:image/s3,"s3://crabby-images/956f6/956f6196942fac1fd231dadee00dcde77fe9699f" alt=""
Allocation Method (配置方法)
- 連續性配置 (contiguous allocation)
- Def: 檔案大小 = n blocks 時, O.S. 需找到連續 free block ≥ n, 方可配置
- 優點:
- search time 短 => 因為 data 鄰近度
- support sequential 及 random access => 處理快
- 缺點:
- 有 external 碎裂
- 檔案大小無法任意擴充
- file size 需事先宣告
(2, 3 會導致沒有彈性)
- Solution:
- Repack (壓縮), 但極度耗時
- disk defragmentation 磁碟重組: 將 file 的分配重組, 以求能達:
- access time 下降 => 速度快
- 連續空間變多 => 外部碎裂下降
- 圖:
data:image/s3,"s3://crabby-images/df832/df832718f16e757c559a2c13b3729b9d2849a20c" alt=""
- 鏈結式配置 (linked allocation)
- Def: 檔案大小 = n blocks 時, O.S. 需找到 free block ≥ n, 即可配置
- 優點:
- No external 碎裂
- 檔案可以擴充
- file size 不需事先宣告
(2, 3 有彈性)
- 缺點:
- search time 長 (因為 data 不見得於鄰近處)
- support sequential 較慢, 不支援 random access
- 圖:
data:image/s3,"s3://crabby-images/55c07/55c07777f2c447bbd79bd1ec2eeeb493632fadc1" alt=""
- FAT (file allocation table)
- Def:
- 用於 Dos, OS/2 之中
- FAT Stored in the disk, 紀錄各 file block 的 link 關係
- Ex:
data:image/s3,"s3://crabby-images/40f3f/40f3fddd92192d9527ee837473920650404017cc" alt=""
- Note: windows PC 版用 “NTFS” 格式
- 圖:
data:image/s3,"s3://crabby-images/95770/95770bbc4d28452098926a68510bad51687cc2a0" alt=""
- 索引配置 (index allocation)
- Def: 各 file 皆有自己的 index block, 用以指向其 block 對應到 disk block 的編號為何
- Ex:
data:image/s3,"s3://crabby-images/7b1d4/7b1d42f946385a852a4cde13da77c818abb37047" alt=""
- 優點:結合 Contiguous Allocation & Linked Allocation 的優點 => speed up 又有彈性
- 缺點:
- index block 需佔用額外空間
- index block 大小不易決定
- i-node (unix-like 常用)
- 概念:
data:image/s3,"s3://crabby-images/6a0b4/6a0b463fc0b58c91b168320547fbb95b48ac43ee" alt=""
- 說明:
1 ~ 12: direct index block (最重要的)
13: single indirect index block
14: double indirect index block
15: triple indirect index block
-
Ex:
1~10: direct block
11: single indirect block
12: double indirect block
13: triple indirect block
each data block = 4 bytes
each index block = 4 k
each index size = 4
total data size = ?
Sol:
10 * 4 bytes
+ 4k/4 * 4 bytes
+
k * k * 4 bytes
+ k * k * k * 4 bytes
= 40 bytes + 4kB + 4k^2B + 4k^3B