SaunaFS is a free and open source, distributed POSIX file system inspired by Google File System. SaunaFS is being developed and maintained by the team from Leil Storage. Designed to run on commodity hardware, SaunaFS is a high-performance, scalable, and reliable file system that provides high availability, data integrity, fault tolerance, and performance on par with local file systems. It is easy to deploy and manage, and it is designed to be used in a wide range of applications, from small clusters to large data centers.
There are a few commercial products built on top of SaunaFS, Leil Storage being the flagship product. Leil Storage = SaunaFS + HM-SMR drives support + ICE + Arctic Forest Concept.
We target the use cases below as primary and this is where we are proud to be a great fit. Contact us to learn more.
- Active Archive
- AI & HPC
- Backup
- CCTV Storage
- Enterprise File Sharing
- Media and Video Post-Production (including proprietary HM-SMR, Windows Client, Connect and Navigator Apps, clustered performant Samba support)
- Resilient architecture: separated components for metadata servers (Master, Shadow, Metaloggers), data servers (Chunkservers), and clients.
- High Availability (HA): uRaft-based metadata failover with coordinated floating IP management for seamless continuity.
- Seamless hardware refresh and expansion: Nodes and drives can be added or replaced without interrupting client access.
- Data integrity: End-to-end data integrity with CRC verification per chunk and periodic validation operations.
- Robust redundancy:
- Erasure Coding (EC): Reed-Solomon
EC(d, p)for high durability, supporting simultaneous loss of up todservers without data loss or service disruption. - Standard replication: Simple mirroring for improved locality and performance, especially for geographically distributed deployments.
- Instant Copy-on-Write Snapshots: Fast and immutable snapshots enabling historical state access and safe filesystem-level rollback.
- Erasure Coding (EC): Reed-Solomon
- Protocol interoperability:
- S3 compatibility: Supported through Versity gateway.
- NFS support: Full NFSv3/NFSv4 support through Ganesha plugin (FSAL).
- Samba/CIFS support: High performance settings for shares on top of Linux native mount points.
-
- Advanced ACL framework: Rich, NFSv4 and POSIX ACL support for precise access management.
- POSIX & flock advisory locking: Includes byte-range locks for concurrent collaborative access.
- Granular quota management: Limits by user, group, and directory with independent caps for size and inode count.
- Fast recursive deletion: Efficient removal of large directory trees via asynchronous task-manager operations.
- Flexible media strategy: HDD, SSD, and NVMe can coexist in the same cluster with labels and goal-based placement for tiering behavior.
- Periodic scrubbing for durability:
- Metadata scans: Validates chunk availability and redundancy compliance.
- Data scrubbing: CRC-based block checking ensures ongoing data correctness.
- Automatic data rebalancing: Reclaims space and redistributes chunks when disks or servers are added or removed.
Please refer to the Installation Guide for detailed instructions on how to install SaunaFS.
Check the Quick Start guide for a simple setup of SaunaFS on a single machine.
After the Quick Start Guide, for an advanced setup, please refer to the Administration Guide as a starting place.
This section assumes you have the necessary dependencies installed. If not, check the Installation Guide for a list of dependencies (at least for Ubuntu) and a more complete guide for compiling from source.
We use nice to set the building process to a lower priority, so it doesn't
hog memory and CPU resources. We also set -j to the number of cores in your
system to speed up the build process. Note that setting -j without nice can
lead to the system running out of memory/hanging.
git clone https://github.com/leil-io/saunafs.git
cd saunafs
mkdir build
cd build
cmake ..
nice -n 16 make -j$(nproc)There are 2 types of documentation available:
- Online documentation for a general overview
- Man pages for specific commands and service configuration
See the Contributing Guide for detailed information on how to contribute to SaunaFS.
The Developer Guide is a good starting point for how to setup a development environment and run tests.
Join our Slack community to connect with fellow SaunaFS enthusiasts, developers, and users. In our Slack channels, you can:
- Ask Questions: Seek guidance, share your experiences, and ask questions related to SaunaFS.
- Discuss Ideas: Engage in discussions about new features, improvements, and best practices.
- Receive Updates: Stay informed about SaunaFS developments, releases, and events.
Join us and be part of the discussion.
Most of the software is licensed under GPLv3, except the Ganesha FSAL, which is
licensed LGPLv3 and located under src/nfs-ganesha/. See the FSAL LICENSE
file for more info.
| Method | Link |
|---|---|
| [email protected] | |
| 🌐 Web | https://saunafs.com |
Thank you for your help.
The SaunaFS Team.
