There are no reviews yet. Be the first to send feedback to the community and the maintainers!
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 1. Table of contents ==================== 0. Introduction 1. Table of contents 2. Getting started - System requirements - Getting the source - Building - Usage 3. About squashfuse - Is squashfuse for you? - What's included? - Features - Known bugs 4. References - Licensing - Acknowledgements - Links 2. Getting started ================== 2a. System requirements ----------------------- To build and use squashfuse, you must be able to use the terminal of your operating system. Runtime requirements: - FUSE 2.5 or later - At least one of the following compression libraries - zlib - lzo2 - xz (aka. liblzma) - lz4 - zstd - (optional) libattr, for better extended attribute support on Linux Build requirements: - A C compiler - make (any variant) - sed - (optional) pkg-config, for detection of dependencies To build from the development repository, rather than a tarball, you'll need: - autoconf 2.60 or later - automake 1.11 or later - libtool 2 Known fully-supported platforms: - Linux - Mac OS X - FreeBSD - NetBSD - OpenIndiana - Android - other platforms may work too! For a precise list of packages you will need on your OS, and other platform notes, please see the file `PLATFORMS'. 2b. Getting the source ---------------------- 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 2c. Installation ---------------- Squashfuse is built with the usual `configure && make'. If you need more detailed instructions: 0. Ensure you're at your terminal, in the directory containing this README. 1. (if needed) If the file `configure' is already present, skip this step. Otherwise, run `./autogen.sh' to generate one. 2. 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. 3. Run `make' to build `squashfuse'. 4. (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. 2d. Example: Ubuntu ------------------- For example on Ubuntu 16.04: sudo apt-get -y install git autoconf libtool make gcc libtool libfuse-dev liblzma-dev libtoolize --force aclocal autoheader automake --force-missing --add-missing autoconf ./configure --with-xz=/usr/lib/ make 2e. Usage --------- 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). 3. About squashfuse =================== 3a. Is squashfuse for you? -------------------------- Squashfuse is a great option if you have a SquashFS archive, and: - You're not running Linux, or - You don't have root access, or - You're too concerned about security to use root, or - You find it inconvenient to elevate privileges, or - SquashFS is not built into your kernel, but FUSE is, or - You want to hack on the SquashFS format without risking kernel panics. 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. 3b. What's included? -------------------- 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. 3c. Features ------------ Squashfuse supports the following SquashFS features: - zlib, LZO, LZMA2, LZ4 and zstd decompression - Fast, indexed directory lookup - Fast, indexed seeking within files - Caching of decompressed blocks - De-duplicated files - Sparse files - Extended attributes - Files larger than 4GB Squashfuse is missing the following features: - LZMA1 compression (deprecated) - Support for SquashFS versions less than 4.0 - Multi-core decompression 3c. Known bugs -------------- - On 32-bit systems with a large inode cache, when mounting a large SquashFS archive created with the "-no-exports" option, squashfuse_ll may use a large amount of memory. This is due to a bug in the FUSE API, where ino_t is shrunk to 32-bits. 4. References ============= 4a. Licensing ------------- Squashfuse is copyright (c) 2012-2014 Dave Vasilevsky <[email protected]> Squashfuse is distributed under the 2-clause BSD license. See the file LICENSE for details. 4b. Acknowledgements -------------------- 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. 4c. Links --------- * SquashFS - SquashFS home page, includeing squashfs-tools: http://squashfs.sourceforge.net/ - squashfs-tools for non-Linux: https://github.com/vasi/squashfs-tools * FUSE - FUSE home page: http://fuse.sourceforge.net/ - OSXFUSE (FUSE for Macs): http://osxfuse.github.io/ * Other implementations of the SquashFS format - Linux kernel: https://github.com/torvalds/linux/tree/master/fs/squashfs - 7-zip / p7zip: http://www.7-zip.org/ - GRUB 2 bootloader: http://www.gnu.org/software/grub/
pixz
Parallel, indexed xz compressorosxutils
Mac-specific command line utilities (UPDATES)positioned-io
Read and write from offsets in Rust.vmdk-raw-parts
Create virtual disks which expose partitions of physical disksqcow2-fuse
Gain access to qcow2 virtual disk images as a user-space filesystemlzopfs
Random access to compressed files with a FUSE filesystemdiskfile
Expose a disk block device as a regular file (FUSE)b2gui
A Mac build of the BasiliskII GUI (OBSOLETE)cloudflare-dns-backup-tool
Backup DNS settings from CloudFlare, and auto-push them to a git repoqcow2-rs
Rust support for qcow2 virtual disk images.partorrent
Download only selected pieces of a torrentevnova-utils
Tools for examining Escape Velocity Nova filesrEFInd
EFI boot manager (PATCHES)macports-tools
Tools for keeping MacPorts tidyhfsj
Hacky write access to journaled HFS+ on Linuxrhfs
Ruby tools for managing HFS disk imagesblock_access_records
Fast block visibility checking for Drupal 8partclone-utils
Mount partclone images (PATCHES)event_sort
Drupal module for custom views sort of eventsvdfuse
Mount virtual disks (FORK)firefox-dock-progress
Displays a progress bar in the Mac OS X dock when files are downloading (deprecated)squash.rb
Pure-ruby squashfs implementationqcow2
qcow2 disk image handling in Go. Also provides a FUSE filesystem!nicotine.app
Nicotine+ built for Mac OS Xlmnopuz
multiplayer web-based crosswords (FORK)pystickies
Print OS X stickies to the terminal, even from another OSmontreal-election-data
Election data for the city of Montrealdebsizes
Find which packages are using all your disk space (PROTOTYPE)repo-backup
Backup repositories from hosting servicestime-machine-size
Determine the disk space used by Time Machine backupsmigrate_process_file
Drupal 8 migration process for importing filesgt5
diff-capable 'du-browser' (PATCHES)resourcefork
Native reading and writing of resource forks in ruby, no Carbon requirednhl_goals
Drupal module to demonstrate scraping paged data with RollingCurlfuse-misc
Miscellaneous small FUSE filesystemsDockProgressTester
Test Firefox Mac dock progress performancebrewfoster
Keep a clean brew installgpt-print
Dump GPT partition tablesdrupal_dbtrace
Tracing DB queries in Drupalvmfuse
Mount foreign filesystems using VirtualBox and lightweight clones (INCOMPLETE)popcon-graph
Terrible attempt at fetching and graphing Ubuntu popcon datagitosis2gitlab
Proxy from old gitosis remotes to gitlabsshjour
SSH to machines that may or may not be on the LANedebtags
Ersatz Debian tags and popularity tooltoggl2rm
Copy timelogs from Toggl to Redminedocker-netbsd-anita
QEMU-based NetBSD docker image, backed by qcow2hotstring
Automatic text expansion in GNOME (proof of concept)NSMine
Bug-fixed and customized version of the minesweeper app (FORK)uzip2ulzma
Convert FreeBSD uzip compressed images to higher-compression ulzmarpmkeeper
Find unused RPM packageskdelibs
KDE core libraries (PATCHES)lvmfuse
Make LVM volumes available via FUSE (UNFINISHED)fuse-uzip
FUSE implementation of FreeBSD's geom_uzip compressed imagesadvent2022
mac-app-format
Show the executable formats of Mac applicationsxmoto-build
Build scripts for X-Moto on OS Xhonduras-election-2013
Scraped data for the Honduras electionmigrate_field_translated
Allow field-translated content to be migrated into Drupal 8 [WIP]Love Open Source and this site? Check out how you can help us