Date: Mon, 26 Sep 2011 14:34:34 -0600 From: Brett Glass <brett@lariat.net> To: Benjamin Kaduk <kaduk@mit.edu> Cc: freebsd-current@freebsd.org Subject: Re: Experiences with FreeBSD 9.0-BETA2 Message-ID: <201109262035.OAA17199@lariat.net> In-Reply-To: <alpine.GSO.1.10.1109261359100.882@multics.mit.edu> References: <201109260053.SAA25795@lariat.net> <201109260927.02540.jhb@freebsd.org> <alpine.GSO.1.10.1109261359100.882@multics.mit.edu>
next in thread | previous in thread | raw e-mail | index | archive | help
At 12:03 PM 9/26/2011, Benjamin Kaduk wrote: >On Mon, 26 Sep 2011, John Baldwin wrote: > >>I can't speak to the "one-big-fs" bit (there was another thread >>long ago about >>that). However, as to the partitioning bit, bsdinstall is >>defaulting to using > >The question of how to layout and split filesystems was discussed >at the filesystems working group of the devsummit at BSDCan this >may. (http://wiki.freebsd.org/201105DevSummit/FileSystems down to >"Filesystem Layout" near the bottom) Though "one big root" did >not garner a huge amount of support, neither were there >particularly compelling arguments against it (if I remember >correctly). It's certainly easier to write an autopartitioner >for, so I don't really blame Nathan for having chosen it initially. My personal preference would be to place portions of the directory tree which contain critical configuration information and are not written in normal use -- e.g. /etc and /boot -- in one or more separate partitions. This would make it possible to mount them read-only unless the system configuration was being changed, new software was being installed, or a new kernel was being generated. This would protect them not only from malicious tampering but also from being scrambled by buggy userland software. And since it would not be written during normal operation, it would survive 100% intact even if journaling and/or serialization of metadata updates (e.g. softupdates) were to fail. Unfortunately, due to past history, /usr is mixed-use. It normally contains both configuration information -- e.g. /usr/local/etc -- and more volatile data such as users' home directories. This prevents /usr/local/etc, which also contains mission-critical configuration information, from being protected if you just protect /. Some proprietary Unices have fixed this historical flaw in the traditional hierarchy by moving /usr/local/etc to another location and them symlinking it back to where seasoned administrators expect it to be, thus honoring POLA. The three open source, old school BSDs (Free, Net, Open) have not done this to date, but it's something that should be considered in the long run. It would certainly make the creation of embedded systems easier, as well as enhancing security in multi-user systems! If I wrote an installer, my preference would be to have it create one partition that contained critical configuration information and software (and could be mounted read-only) and one that contained the rest of the usual directory tree (and could be mounted read-write). It could do the symlinking trick mentioned above to bring parts of /usr over to the read-only administrative partition. The only cleanup task that would remain would be to make sure that no ports were configured to place their logs, pid files, etc. in directories such as /usr/local/etc. (Most already do not.) --Brett
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201109262035.OAA17199>