Last updated on September 22, 2020 by Dan Nanni
If you often mount and access a remote NFS share on your system, you will probably want to know how to improve NFS file access performance. One possibility is using file caching. In Linux, there is a caching filesystem called FS-Cache which enables file caching for network file systems such as NFS. FS-Cache is built into the Linux kernel 2.6.30 and higher.
In order for FS-Cache to operate, it needs cache back-end which provides actual storage for caching. One such cache back-end is cachefiles. Therefore, once you set up cachefiles, it will automatically enable file caching for NFS shares.
In this tutorial, I will describe how to enable local file caching for NFS shares by using cachefiles.
One requirement for setting up cachefiles is that local filesystem support user-defined extended file attributes (i.e., xattr), because cachefiles use xattr to store extra information for cache maintenance.
If your local filesystem is EXT4-type, you don't need to worry about this since xattr is enabled in EXT4 by default.
However, if you are using EXT3 filesystem, then you need to mount the local filesystem with user_xattr option. To do so, edit /etc/mtab to add user_xattr mount option to the disk partition that will be used by cachefiles for file caching. For example, assuming that /dev/hda1 is such a partition:
/dev/hda1 / ext3 rw,user_xattr 0 0
After modifying /etc/fstab, reload it by running:
$ sudo mount -o remount /
In order to set up cache back-end using cachefiles, you need to install cachefilesd, a userspace daemon for managing cachefiles.
To install cachefilesd on Ubuntu or Debian:
$ sudo apt-get install cachefilesd
To install cachefilesd on CentOS, Fedora or RedHat:
$ sudo yum install cachefilesd $ sudo chkconfig cachefilesd on
After installation, enable cachefilesd by editing its configuration file as follows.
$ sudo vi /etc/default/cachefilesd
RUN=yes
Next, mount a remote NFS share with fsc option:
$ sudo vi /etc/fstab
192.168.1.13:/home/xmodulo /mnt nfs rw,hard,intr,fsc
Alternatively, if you mount the remote NFS share from the command line, specify fsc as a command-line option:
$ sudo mount -t nfs 192.168.1.13:/home/xmodulo /mnt -o fsc
Finally, restart cachefilesd:
$ sudo service cachefilesd restart
At this point, file caching should be enabled for the mounted NFS share, which means that previously accessed files in the mounted NFS share will be retrieved from local file cache.
If you want to flush NFS file cache for any reason, simply restart cachefilesd.
$ sudo service cachefilesd restart
This website is made possible by minimal ads and your gracious donation via PayPal or credit card
Please note that this article is published by Xmodulo.com under a Creative Commons Attribution-ShareAlike 3.0 Unported License. If you would like to use the whole or any part of this article, you need to cite this web page at Xmodulo.com as the original source.
Xmodulo © 2021 ‒ About ‒ Write for Us ‒ Feed ‒ Powered by DigitalOcean