Item2: Support multiple extents for storing large files (filesize > bandsize)
Priority: |
CurrentState: |
AppliesTo: |
Component: |
WaitingFor: |
Enhancement |
Closed |
SMR |
|
PratikShah |
--
PratikShah - 18 Oct 2013
The max size of one band is 4096 blocks * 4096 blocksize = 16 MB. In the LFStest, at the end of sequential write, it issues an fsync on the largefile fd. When this happens, the largefile, which is actually in buffercache is now enqueud to be synced or written to the disk. This write to disk is performed by bc_worker. bc_worker tries to find the band with max free size to write this file on the disk. The max free size for a band is 16MB as discussed above. Thus for files greater than 16MB, this request fails, hence it asserts. The issue is that bc_worker doesn't split the write workload in multiple bands. For example, to write a file of 17MB, bc_worker requests for a band to store 4352 blocks (4352 * 4096 = 17MB), however the max free size for any band is 4096, hence that request fails. Thus bc_worker thinks there are no available bands to write the file.
Possible changes required:-
- Method to break file into multiple extents
- Change to inode structure for holding information about multiple extents
- Changes to way open and read will operate using multiple extents.