RFUSE: Modernizing Userspace Filesystem Framework through Scalable Kernel-Userspace Communication [FAST '24]
This repository contains the artifact for reproducing our FAST '24 paper "RFUSE: Modernizing Userspace Filesystem Framework through Scalable Kernel-Userspace Communication".
root
|---- driver (Source code of kernel drivers)
|---- fuse
|---- rfuse
|---- lib (Source code of user-level libraries)
|---- libfuse
|---- librfuse
|---- linux (Linux kernel 5.15.0)
|---- filesystems (User level filesystems)
|---- nullfs (Source code of NullFS)
|---- stackfs (Source code of StackFS)
|---- bench
|---- unit (Unit test for latency breakdown; Figure 2 and Figure 7)
|---- fio (Fio benchmark scripts; Figure 8)
|---- scale_fio (I/O scalability benchmark based on fio; Figure 10)
|---- fxmark (Fxmark benchmark source code and scripts; Figure 11)
|---- filebench (Filebench workloads and scripts; Figure 12)
- 2-socket x86_64 CPU (40 cores per socket)
- 256 GB DRAM
- PCIe Gen 4.0 NVMe SSD
- OS distribution: Ubuntu 20.04.5 LTS
- Linux kernel version: 5.15.0
sudo apt install build-essential make ninja-build meson pkg-config autoconf kernel-package libncurses5-dev bison flex libssl-dev fio python2 libelf-dev rsync zstd udev
$ git clone https://github.com/WithoutStress/rfuse-fast24-ae.git
$ cd rfuse-fast24-ae
$ cd linux
$ sudo make menuconfig # --> CONFIG_FUSE_FS=m
$ sudo make-kpkg -j N --initrd --revision=1.0 kernel_image kernel_headers
$ cd ..
$ sudo dpkg -i *.deb
--> Update grub to load v5.15.0 and reboot
RFUSE uses per-core ring channel for request communication. Before installing user library and kernel driver, users should configure the number of ring channel as the number of CPU cores in the machine.
# (librfuse)
$ cd lib/librfuse
$ vi include/rfuse.h
# (rfuse kernel driver)
$ cd driver/rfuse
$ vi rfuse.h
--> Change the value of RFUSE_NUM_IQUEUE to the number of core in machine.
# (librfuse)
$ cd lib/librfuse
$ ./librfuse_install.sh
# (rfuse kernel driver)
$ cd driver/rfuse
$ make
$ ./rfuse_insmod.sh first # (if insmod the driver first time after reboot)
$ ./rfuse_insmod.sh # (if the driver is already insmoded)
- If you want to install native fuse user library and kernel driver, move to
lib/libfuse
anddriver/fuse
, and run prepared installation scripts in that directories. - Add the location of the library to tell the dynamic link loader where to search for the library.
# Ubuntu (Add below line into .bashrc for system-wide adoption).
$ export LD_LIBRARY_PATH=/usr/local/lib/x86_64-linux-gnu:${LD_LIBRARY_PATH}
# Debian
$ echo "/usr/local/lib/x86_64-linux-gnu" > /etc/ld.so.conf.d/rfuse.conf
1. NullFS
NullFS is a very simple userspace filesystem that only supports the STAT operation on the root directory.
$ cd filesystems/nullfs
$ make
$ ./run.sh
2. StackFS
StackFS is a stackable userspace filesystem that forwards incoimming filesystem operations to an underlying in-kernel filesystem. To mount StackFS, users need to set a base device for the underlying filesystem. Please configure DEVICE_NAME
in stackfs/run.sh
.
If you are utilizing a Chameleon Cloud instance and tryting to build from scratch, please be aware that the stackfs/run.sh
script only supports the option ssd-noclean
because of the absensce of an additional device to be used for an underlying in-kernel filesystem. Consequently, the root filesystem is employed as the underlying file system.
$ cd filesystems/stackfs
$ make
$ ./run.sh ssd # (Format base device first and mount StackFS)
$ ./run.sh ssd-noclean # (Mount StackFS without formatting base device)
Please refer to Experiment Guide
When contributing to this repository, please first discuss the change you wish to make via issues or email([email protected]) before making a change.
- Create a personal fork of the project on Github.
- Clone the fork on your local machine.
- Implement/fix your feature, comment your code.
- Follow the code style of this project, including indentation.
- Run tests based on the Experiment Guide
- From your fork open a pull request in our
master
branch! - Please wait for the maintainer's review.