Grid file system


A grid file system is a computer file system whose goal is improved reliability and availability by taking advantage of many smaller file storage areas.

Components

File systems contain up to three components:
A grid file System would have similar needs:
Because file systems are designed to appear as a single disk for a single computer to manage, many new challenges arise in a grid scenario whereby any single disk within the grid should be capable of handling requests for any data contained in the grid.

Features

Most file storage utilizes layers of redundancy to achieve a high level of data protection. Current means of redundancy include replication and parity checks. Such redundancy can be implemented via a RAID array.
Similarly, a grid file system would consist of some level of redundancy across the various disks present in the "grid".

Framework

First and foremost, a file table mechanism is necessary. Additionally, the file table must include a mechanism for locating the file within the grid.
Secondly, a mechanism for working with file data must exist. This mechanism is responsible for making file data available to requests.

Implementation

With BitTorrent technology, a parallel can be drawn to a grid file system, in that a torrent tracker would be the "file table", and the torrent applications would be the "file data" component.
An RSS feed like mechanism could be utilized by file table nodes to indicate when new files are added to the table, to instigate replication and other similar components.
A file system may incorporate similar technology.
If both such systems were capable of being addressed as a single entity, then growth into such a system could be easily controlled simply by deciding which uses the grid member would be responsible.

Availability

Assuming there exists some method of managing data replication autonomously within the grid, data could be configured for high availability, regardless of loss or outage.

Challenges

The largest problem currently revolves around distributing data updates. Torrents support minimal hierarchy. Updating multiple nodes concurrently presents latency during updates and additions, usually to the point of not being feasible.
Additionally, a grid file system breaks traditional TCP/IP paradigms in that a file system require complicated TCP/IP implementations, introducing layers of abstraction and complication to the process of creating such a grid file system.

Examples

Examples of high-available data include: