33

I'm planning to deploy some kiosk computers and would like to leave them with a small pendrive as boot disk, keeping the rest at an easy to back up server, ala LTSP.

Right now I'm pondering two options. An NFSed /home/, or a local copy of ~/ copied on login, rsynced on logout.

My fears are that working with files might get too slow, or my network might get clogged.

voyager
  • 698
  • 1
  • 6
  • 13
  • Could you please replace "safe" with another word that's less related to security? Maybe feasible http://www.merriam-webster.com/dictionary/feasible ? – Cristian Ciupitu Jun 04 '09 at 02:42
  • 1
    A slight sense of déja vu. It's not the exact same thing, but it's an interesting thread they've got there. http://hardware.slashdot.org/story/09/06/23/1823201/How-Do-You-Sync-amp-Manage-Your-Home-Directories – voyager Jun 23 '09 at 22:52

10 Answers10

34

I use NFS for my home directories in our production environment. There are a couple of tricks.

  1. Don't NFS mount to /home - that way you can have a local user that allows you in in the event that the NFS server goes down. We mount to /mnt/nfs/home

  2. Use soft mounts and a very short timeout - this will prevent processes from blocking forever.

  3. Use the automounter. This will keep resource usage down and also means that you don't need to worry about restarting services when the NFS server comes up if it goes down for some reason.

    auto.master:
      +auto.master
      /mnt/nfs /etc/auto.home --timeout=300
    
    auto.home
       home -rw,soft,timeo=5,intr      home.bzzprod.lan:/home
    
  4. Use a single sign-on system so you don't run into permission related issues. I have an OpenLDAP server.

JohannesM
  • 166
  • 2
  • 13
Aaron Brown
  • 1,677
  • 1
  • 12
  • 21
  • I've always found the automounter horribly unreliable and prone to locking up, especially if the NFS server goes down. If you mount to /mnt/nfs/home, is that where you set the user's home in /etc/passwd? – pjc50 Oct 14 '09 at 14:16
  • 2
    Well, using /etc/passwd and NFS mounting home dirs is a bad idea, as you have to keep the UID and GIDs in sync - use something like OpenLDAP, but yes, the user's home dir is set to /mnt/nfs/home/username. – Aaron Brown Dec 08 '09 at 15:06
  • @AaronBrown I agree that if you're going to put $HOME on the network, you should also put user identity and authentication on the network as well. Regardless of how you do that, $HOME has to be defined somewhere and you've indicated that you prefer to set it to `/mnt/nfs/home` but how then do you utilize your local `/home` during an outage? Specifically, please see https://unix.stackexchange.com/questions/189404/how-to-keep-a-redundant-home-directory-for-offline-use – JFlo Aug 10 '17 at 13:24
  • On Ubuntu systems, install the `autofs` package to enable automounter features: `apt-get install autofs`. – Johnny Utahh Sep 03 '20 at 15:31
7

HowtoForge posted an article titled Creating An NFS-Like Standalone Storage Server With GlusterFS On Debian Lenny, you may want to check it out.

Here is a short description of why it's a good "feasible" alternative to NFS, from the GlusterFS project page:

GlusterFS self-heals itself on the fly. There is no fsck. Storage backend is accessible directly as regular files and folders (NFS style). With replication enabled, GlusterFS can with-stand hardware failures.

More information can be found in the project documentation.

Also, another nice thing about using GlusterFS is if you need more space on your SAN you just add another storage brick (server node) and you are able to scale/grow your storage in parallel when there is need.

Cristian Ciupitu
  • 6,226
  • 2
  • 41
  • 55
faultyserver
  • 1,904
  • 1
  • 16
  • 20
7

Be careful with the soft mounts! Soft mounting an NFS filesystem means IO will fail after a timeout occurs. Be very sure that is what you want on users' home directories! My guess is you don't. Using a hard mount on home directories in combination with the intr option feels a lot safer here.

Hard will not timeout: IO operations will be retried indefinitely. The intr option makes it possible to interrupt the mounting process. So if you mount the export and experience a failure, the hard-mount will lock your session. The intr option will make it possible to interrupt the mount, so the combination is pretty safe and ensures you will not easily lose a user's data.

Anyway, autofs makes this all even easier.

Dennis Williamson
  • 60,515
  • 14
  • 113
  • 148
wzzrd
  • 10,269
  • 2
  • 32
  • 47
  • 1
    note that the `intr` mount option has been deprecated in linux after kernel 2.6.2, see e.g. https://access.redhat.com/solutions/157873 – myrdd Apr 20 '18 at 22:46
5

The one thing to note is that when the NFS server is out - your mounts will freeze - doing a soft mount will not block so the "freeze" itself can be avoided, however that will not fix the problem of home directories as without a home directory, the user is screwed anyway.

Even when the NFS server recovers, unless you do something about it, the freeze problem will remain - you'll have to kill the process on the mounting machine, and remount. The reason for this is that when the NFS server comes back up, it assigned a different fsid - so you can at least fix this problem by hard-coding the fsids on the NFS server, for example...

#. Home Directories
/usr/users \
  192.168.16.0/22(rw,sync,no_root_squash,fsid=1) \
  192.168.80.0/22(rw,sync,no_root_squash,fsid=1)

#. Scratch Space
/var/ftp/scratch \
  192.168.16.0/22(rw,async,no_root_squash,fsid=3) \
  192.168.80.0/22(rw,async,no_root_squash,fsid=3) \
  172.28.24.151(rw,async,root_squash,fsid=3)

The exports(5) man page states...

fsid=num
          This option forces the filesystem identification portion of the file handle
          and  file attributes used on the wire to be num instead of a number derived
          from the major and minor number of the block device on which the filesystem
          is  mounted.   Any 32 bit number can be used, but it must be unique amongst
          all the exported filesystems.

          This can be useful for NFS failover, to ensure that  both  servers  of  the
          failover  pair use the same NFS file handles for the shared filesystem thus
          avoiding stale file handles after failover.

...While that indicates that as long as the major/minor numbers do not change (which they usually don't, except for when you're exporting SAN/multipath volumes, where the may change), I've found that we've completely removed the problem - i.e., if the NFS server comes back - the connection has been restored quickly - I still really don't know why this has made a difference for devices such as /dev/sdaX for example.

I should now point out that my argument is largely anecdotal - it doesn't actually make sense why it has fixed the problem, but it "seems" to have fixed it - somehow - there are probably other variables at play here that I've not yet discovered. =)

Xerxes
  • 4,133
  • 3
  • 26
  • 33
  • Are you sure about this "random" fsid used by the server? – Cristian Ciupitu Jun 04 '09 at 02:33
  • Hi Cristian - I've tried to explain above - but I can't fully explain the behavior with respect to the man page description of the flag. Have you tried it and seen otherwise? – Xerxes Jun 04 '09 at 03:26
4

Some general advice that will apply no matter which network filesystem you adopt: many programs cache data in the user's home directory, which usually does more harm than good when the home directory is accessed over a network.

These days, you can tell many programs to store their caches elsewhere (e.g., on a local disk) by setting the XDG_CACHE_HOME environment variable in a login script. Lots of programs (e.g., Firefox) still require manual configuration, however, so you will probably have to do some extra work to identify and configure them in a uniform manner for all your users.

Sam Morris
  • 345
  • 1
  • 10
  • +1 I've had performance problems with Google Chrome and NFS home dirs. fixed it by moving Chrome's working directories back to the local system, then placing a symlink from the NFS home dir (where Chrome expects to find the dirs), back to the local directory. There may be a better way of doing what I've done, but it solved the problem for me. – Bryan Mar 09 '12 at 13:37
  • Bryan (march 9) left a good partial answer, however, I want to elaborate on this issue. Please do... Thank you.. How did you move the working directories to the local machine, and place symlinks. – Jason Oct 04 '12 at 01:59
  • Also look into the ``XDG_RUNTIME_DIR`` described for Dconf database location at: https://developer.gnome.org/dconf/unstable/dconf-overview.html – JKnight Jul 01 '14 at 21:17
3

I lot of places I have worked use NFS mounted home directories. There usually isn't a huge difference in performance (and kiosk users are probably a bit less demanding than developers who know how to get hold of their local IT guy). One problem I have seen is what happens when I'm logged into a Gnome desktop and the NFS server goes away for whatever reasons. Things get real unresponsive.

kbyrd
  • 3,604
  • 2
  • 23
  • 34
2

I use an NFSed home and it works fine. but you must make sure the network is fast enough and that it will never be down.

cd1
  • 1,434
  • 4
  • 12
  • 17
2

On a practical basis, NFS performs well for home directory if there's a 100mbit switched network or better. For more then 10-20 kiosks, the server should have gigabit connectivity. You won't win performance contests, but things like Firefox and Open Office will work okay.

Copying in the home directory will be a major pain in term of delays at login (on a 100mbit network that's max 12MB/s. A 100MB home directory is close to 10 seconds.) Rsync will thrash you syncing web browser cache... 10 minutes and 500 files hurt.

1

Note that in some cases (eg. private home use, or kiosk config), the simplest thing to do might be to use symlinks for important top-level directories inside the home directory. Makes it a lot easier to nuke the "satellite" home if settings there get screwed up, need to be kept local, etc.

matt
  • 11
  • 1
1

Have a look at cachefilesd. I haven't used it myself, but it looks promising.

The cachefilesd daemon manages the caching files and directory that are that are used by network filesystems such a AFS and NFS to do persistent caching to the local disk.

Also, don't forget to tune the rsize and wsize parameters and use Jumbo frames if possible.

Cristian Ciupitu
  • 6,226
  • 2
  • 41
  • 55
  • I've tried cachefilesd for several years but gave up due to all the instability it brought. YMMV – JFlo Aug 10 '17 at 13:16