squashfuse - Mount SquashFS archives using FUSE
https://github.com/vasi/squashfuse
Squashfuse lets you mount SquashFS archives in user-space. It supports almost all features of the SquashFS format, yet is still fast and memory-efficient. So that everyone can use it, squashfuse supports many different operating systems and is available under a permissing license.
SquashFS is an efficiently compressed, read-only storage format. Support for it has been built into the Linux kernel since 2009. It is very common on Live CDs and embedded Linux distributions.
Quick start: $ ./configure && make $ ./squashfuse foo.squashfs mountpoint
Introduction
Table of contents
Getting started
About squashfuse
References
To build and use squashfuse, you must be able to use the terminal of your operating system.
Runtime requirements:
Build requirements:
To build from the development repository, rather than a tarball, you'll need:
Known fully-supported platforms:
For a precise list of packages you will need on your OS, and other platform notes, please see the file `PLATFORMS'.
The squashfuse distribution can be downloaded from SourceForge: https://sourceforge.net/projects/squashfuse/files/
The development repository uses git, at GitHub: http://github.com/vasi/squashfuse
Squashfuse is built with the usual `configure && make'. If you need more detailed instructions:
Ensure you're at your terminal, in the directory containing this README.
(if needed) If the file configure' is already present, skip this step. Otherwise, run
./autogen.sh' to generate one.
Run ./configure' to set up the build. You can find useful configuration options in the file
CONFIGURATION', or by running `./configure --help'.
If configure fails, check that you really have all the requirements installed. You may also want to check the `PLATFORMS' file to see if there are any special notes for your operating system.
Run make' to build
squashfuse'.
(optional) If you want to use squashfuse in this directory, that's ok.
But if you'd rather install it, run make install'. If you need root privileges,
sudo make install' may work.
For example on Ubuntu 22.04:
$ sudo apt install gcc make pkg-config libfuse3-dev \ zlib1g-dev liblzo2-dev liblzma-dev liblz4-dev libzstd-dev \ automake autoconf libtool \ fuse3 fio squashfs-tools $ ./autogen.sh $ ./configure $ make -j4 $ make check $ sudo make install
For example on NixOS:
$ nix-shell $ ./autogen.sh $ ./configure $ make -j4
To install to your system, a custom Nix package should be built. Otherwise, you can simply move the binaries to `~/.local/bin'
On macOS, for example, install macFUSE, and then:
$ brew install autoconf automake pkg-config libtool lzo xz $ ./autogen.sh $ ./configure --prefix=/usr/local/ \ --with-lzo=/usr/local/Cellar/lzo/2.10 \ --with-xz=/usr/local/Cellar/xz/5.4.4 $ make -j $ make check $ make install
You'll need a SquashFS archive to use squashfuse. If you don't already have one, you can create one using the `mksquashfs' utility from the squashfs-tools project.
To create a SquashFS archive: $ mksquashfs DIRECTORY ARCHIVE
To mount a SquashFS archive with squashfuse: $ squashfuse ARCHIVE MOUNTPOINT
To unmount when you're done: $ umount MOUNTPOINT # On Mac/BSD $ fusermount -u MOUNTPOINT # On Linux
For more options, see the man page squashfuse(1).
Squashfuse is a great option if you have a SquashFS archive, and:
Squashfuse is probably not the right tool for the job, if:
You don't have FUSE. More and more systems have FUSE, but some don't. Squashfuse requires it.
You have a very old SquashFS archive. Neither squashfuse nor the Linux kernel support SquashFS versions less than 4.0. Use `unsquashfs' from the squashfs-tools project.
You want to create or modify a SquashFS archive. Neither squashfuse nor the Linux kernel support write access, use `mksquashfs' from squashfs-tools.
You want to extract an entire SquashFS archive. If you don't want to mount anything, it's more efficient and convenient to just use unsquashfs.
You want your root filesystem `/' to be SquashFS. This isn't well-tested, though it may be possible.
You're highly concerned about bugs. The SquashFS kernel module has seen much more testing than squashfuse.
If you don't yet use SquashFS, consider starting, now that squashfuse exists. For many uses, the chief drawbacks of SquashFS were requiring Linux and root access, but squashfuse has that covered.
Use SquashFS for archival and backup, instead of tar. It offers faster creation (multi-core), and browsing without unpacking.
Use SquashFS instead of zip. It has better compression, and faster directory lookup.
Use SquashFS instead of compressed disk images like DMG, uzip or Partimage. It has better compression and portability.
Squashfuse currently comprises three programs:
squashfuse Allows you to mount a squashfs filesystem.
squashfuse_ll Like `squashfuse', but implemented using the low-level FUSE API. It's a tiny bit faster, but less portable.
squashfuse_ls Lists all the files in a squashfs archive. A demonstration of using the squashfuse core in the absence of FUSE.
Squashfuse supports the following SquashFS features:
Squashfuse is missing the following features:
Squashfuse is copyright (c) 2012-2014 Dave Vasilevsky dave@vasilevsky.ca Squashfuse is distributed under the 2-clause BSD license. See the file LICENSE for details.
Thanks to:
Phillip Lougher, for designing the SquashFS format, and implementing support in the kernel. Also for providing permission to use and distribute squashfs_fs.h under a BSD-style license.
Maël Kerbiriou, for implementing LZ4 support.
SquashFS
FUSE
Other implementations of the SquashFS format