MooseFS - A Petabyte Distributed File System
MooseFS is a Petabyte Open Source Network Distributed File System. It is easy to deploy and maintain, fault tolerant, highly performing, easily scalable, POSIX compliant.
MooseFS spreads data over several physical commodity servers, which are visible to the user as one big volume. For standard file operations MooseFS acts like ordinary Unix-like file system:
- A hierarchical structure (directory tree)
- Stores POSIX file attributes (permissions, last access and modification times, etc.)
- Supports ACLs
- Supports POSIX and BSD locks
- Supports special files (block and character devices, pipes and sockets)
- Symbolic links (file names pointing to target files, not necessarily on MooseFS) and hard links (different names of files which refer to the same data on MooseFS)
Distinctive MooseFS features:
- High reliability - configurable number of files' copies are stored on separate servers
- No Single Point of Failure - all hardware and software components may be redundant
- Parallel data operations - many clients can access many files concurrently
- Capacity can be dynamically expanded by simply adding new computers/disks on the fly
- Retired hardware may be removed on the fly
- Deleted files are retained for a configurable period of time (a file system level "trash bin")
- Coherent, "atomic" snapshots of files, even while the files are being written/accessed
- Access to the file system can be limited based on IP address and/or password (similarly as in NFS)
- Data tiering - supports different storage policies for different files/directories
- Efficient, pure C implementation
- Ethernet support
MooseFS can be installed on any POSIX compliant operating system including different Linux distributions, FreeBSD, OS X:
- MacOS X
- Raspbian - Raspberry Pi 3
MooseFS Client uses FUSE.
There is a separate MooseFS Client for MS Windows available, built on top of Dokany.
You can install MooseFS using your favourite package manager on one of the following platforms using officially supported repositories:
- Ubuntu 14/16/18
- Debian 8/9
- RHEL/CentOS 6/7
- FreeBSD 9.3/10/11
- MacOS X 10.9-10.13
- Raspbian 8 (Jessie) - Raspberry Pi 3
Minimal set of packages, which are needed to run MooseFS:
moosefs-masterMooseFS Master Server for metadata servers,
moosefs-chunkserverMooseFS Chunkserver for data storage servers,
moosefs-clientMooseFS Client - client side package to mount the filesystem.
Feel free to download source code either from GitHub code repository or from our website archives.
Install the following dependencies before building MooseFS from sources:
sudo apt install build-essential libpcap-dev zlib1g-dev libfuse-dev pkg-config
sudo yum install gcc make libpcap-devel zlib-devel fuse-devel pkgconfig
sudo apt install fuse
sudo yum install fuse
Building MooseFS on Linux can be easily done by running
./linux_build.sh. Similarly, use
./freebsd_build.sh in order to build MooseFS on FreeBSD and respectively
./macosx_build.sh on MacOS X. Remember, that those scripts do not install (i.e. do not run
make install at the end). Run this command manually.
Just three steps to have MooseFS up and running:
1. Install at least one Master Server
- Prepare default config (as
cd /etc/mfs cp mfsmaster.cfg.sample mfsmaster.cfg cp mfsexports.cfg.sample mfsexports.cfg
- Prepare the metadata file (as
cd /var/lib/mfs cp metadata.mfs.empty metadata.mfs chown mfs:mfs metadata.mfs rm metadata.mfs.empty
- Run Master Server (as
- Make this machine visible under
mfsmastername (e.g. by adding a DNS entry or adding it in
/etc/hostson all servers)
2. Install at least two Chunkservers
- Prepare default config (as
cd /etc/mfs cp mfschunkserver.cfg.sample mfschunkserver.cfg cp mfshdd.cfg.sample mfshdd.cfg
- At the end of
mfshdd.cfgfile make one or more entries containing paths to HDDs / partitions designated for storing chunks, e.g.:
/mnt/chunks1 /mnt/chunks2 /mnt/chunks3
It is recommended to use XFS as an underlying filesystem for disks designated to store chunks.
- Change the ownership and permissions to
mfs:mfsto above mentioned locations, e.g.:
chown mfs:mfs /mnt/chunks1 /mnt/chunks2 /mnt/chunks3 chmod 770 /mnt/chunks1 /mnt/chunks2 /mnt/chunks3
- Start the Chunkserver:
Repeat steps above for second (third, ...) Chunkserver.
3. Client side: mount MooseFS filesystem
moosefs-client fuse libfuse2packages
- Mount MooseFS (as
mkdir /mnt/mfs mount -t moosefs mfsmaster: /mnt/mfs
mfsmount -H mfsmaster /mnt/mfs
- You can also add an
/etc/fstabentry to mount MooseFS during the system boot:
mfsmaster: /mnt/mfs moosefs defaults,mfsdelayedinit 0 0
There are more configuration parameters available but most of them may stay with defaults. We do our best to keep MooseFS easy to deploy and maintain.
MooseFS, for testing purposes, can even be installed on a single machine!
moosefs-cgi both with
moosefs-cgiserv is also recommended - it gives you a possibility to monitor the cluster online:
moosefs-cli moosefs-cgi moosefs-cgiservpackages (they are typically set up on the Master Server)
- Run MooseFS CGI Server (as
- Open http://mfsmaster:9425 in your web browser
It is also strongly recommended to set up at least one Metalogger on a different machine than Master Server (e.g. on one of Chunkservers). Metalogger constantly synchronizes and backups the metadata:
- Prepare default config (as
cd /etc/mfs cp mfsmetalogger.cfg.sample mfsmetalogger.cfg
- Run Metalogger (as
Refer to installation guides for more details.
- Date of the first public release: 2008-05-30
- The project web site: https://moosefs.com
- Installation and using MooseFS: https://moosefs.com/support
- (Old) Sourceforge project site: http://sourceforge.net/projects/moosefs
Copyright (c) 2018 Jakub Kruszona-Zawadzki, Core Technology Sp. z o.o.
This file is part of MooseFS.
MooseFS is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2 (only).
MooseFS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with MooseFS; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA or visit http://www.gnu.org/licenses/gpl-2.0.html.