File::LinearRaid - Treat multiple files as one large seamless file for reading and writing.
use File::LinearRaid; my $fh = File::LinearRaid->new( "+<", "data/datafile0" => 100_000, "data/datafile1" => 50_000, "data/datafile2" => 125_000 ); ## this chunk of data actually crosses a physical file boundary seek $fh, 90_000, 0; read $fh, my $buffer, 20_000; ## replace that chunk with X's seek $fh, 90_000, 0; print $fh "X" x 20_000;
This module provides a single-filehandle interface to multiple files, in much the same way that a linear RAID provides a single-device interface to multiple physical hard drives.
This module was written to provide random fixed-width record access to a series of files. For example, in the BitTorrent filesharing protocol, several files are shared as a single entity. The final sizes of the individual files are known, but the protocol only sends fixed-width chunks of data. These chunks are not aligned to file boundaries and can span several physical files, but they are only identified by their overall offset and not by the files they span.
This module was created to provide a layer of abstraction around this kind of storage. Instead of calculating possibly many file offsets, and dividing data into smaller pieces, a simple seek and read (or print) on the abstract filehandle will do the right thing, regardless of how the chunk spans the physical files:
seek $fh, ($chunk_id * $chunk_size), 0; read $fh, my $buffer, $chunk_size; ## or if opened with mode "+<" or similar: seek $fh, ($chunk_id * $chunk_size), 0; print $fh $chunk;
This module may prove useful if your physical file system has a low (2G) limit on file sizes, yet you require access and storage for a large amount of data through a single filehandle.
my $fh = File::LinearRaid->new( $mode, $path1 => $size1, ... )
Returns a new aggregate filehandle consisting of the listed paths in that order. Each physical file is opened using the given mode (Note: if
+>, all files will be truncated before opening -- see open). If there is an error opening a file, croaks.
For each file, you must specify a maximum length. This need not be the current length of the file:
$modedoesn't truncate it first.
$fh->append( $path1 => $size1, ... )
Append new file(s) to the end of the aggregate filehandle, with the given size(s). Returns a true value if successful, otherwise croaks.
Returns the current maximum size of the aggregate filehandle.
open are implemented, so you should be able to use most file operations seamlessly. Writing to the aggregate filehandle past the total length is not supported. In other words, the final physical file will not be grown as needed. You must use
seekto a BigInt value on the aggregate filehandle, but this is not guaranteed to work.
File::LinearRaid is written by Mike Rosulek <email@example.com>. Feel free to contact me with comments, questions, patches, or whatever.
Copyright (c) 2004 Mike Rosulek. All rights reserved. This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.