A Versatile and User-Oriented Versioning File System

File versioning is a useful technique for recording a history of changes. Applications of versioning include backups and disaster recovery, as well as monitoring intruders' activities. Alas, modern systems do not include an automatic and easy-to-use file versioning system. Existing backup solutions are slow and inflexible for users. Even worse, they often lack backups for the most recent day's activities. Online disk snapshotting systems offer more fine-grained versioning, but still do not record the most recent changes to files. Moreover, existing systems also do not give individual users the flexibility to control versioning policies. We designed a lightweight user-oriented versioning file system called Versionfs. Versionfs works with any file system and provides a host of user-configurable policies: versioning by users, groups, processes, or file names and extensions; version retention policies and version storage policies. Versionfs creates file versions automatically, transparently, and in a file-system portable manner--while maintaining Unix semantics. A set of user-level utilities allow administrators to configure and enforce default policies: users can set policies within configured boundaries, as well as view, control, and recover files and their versions. We have implemented the system on Linux. Our performance evaluation demonstrates overheads that are not noticeable by users under normal workloads.

[1]  Randal Burns,et al.  Ext3cow: The Design, Implementation, and Analysis of Metadata for a Time-Shifting File System , 2003 .

[2]  Sailesh Chutani,et al.  The Episode File System , 1992 .

[3]  Craig A. N. Soules,et al.  Metadata Efficiency in Versioning File Systems , 2003, FAST.

[4]  Kirby McCoy VMS File System Internals , 1990 .

[5]  Norman C. Hutchinson,et al.  Deciding when to forget in the Elephant file system , 1999, SOSP.

[6]  Erez Zadok,et al.  Fast Indexing: Support for Size-Changing Algorithms in Stackable File Systems , 2001, USENIX Annual Technical Conference, General Track.

[7]  Margo I. Seltzer,et al.  NFS Tricks and Benchmarking Traps , 2003, USENIX Annual Technical Conference, FREENIX Track.

[8]  Erez Zadok,et al.  FIST: a language for stackable file systems , 2000, OPSR.

[9]  Mahadev Satyanarayanan,et al.  Disconnected Operation in the Coda File System , 1999, Mobidata.

[10]  Sean Quinlan,et al.  Venti: A New Approach to Archival Storage , 2002, FAST.

[11]  Margo Seltzer,et al.  The Utility of File Names , 2003 .

[12]  Craig A. N. Soules,et al.  Self-securing storage: protecting data in compromised systems , 2000, Foundations of Intrusion Tolerant Systems, 2003 [Organically Assured and Survivable Information Systems].

[13]  James E. Johnson,et al.  Overview of the Spiralog File System , 1996, Digit. Tech. J..

[14]  Chandramohan A. Thekkath,et al.  Petal: distributed virtual disks , 1996, ASPLOS VII.

[15]  Steve R. Kleiman,et al.  SnapMirror: File-System-Based Asynchronous Mirroring for Disaster Recovery , 2002, FAST.

[16]  Erez Zadok,et al.  Tracefs: A File System to Trace Them All , 2004, FAST.

[17]  David K. Gifford,et al.  The Cedar file system , 1988, CACM.

[18]  James Lau,et al.  File System Design for an NFS File Server Appliance , 1994, USENIX Winter.

[19]  Sean Quinlan,et al.  A cached WORM file system , 1991, Softw. Pract. Exp..