Date: Thu, 27 Sep 2007 20:37:24 +0900 From: Daichi GOTO <daichi@freebsd.org> To: freebsd-current@FreeBSD.ORG, Masanori OZAWA <ozawa@ongs.co.jp> Subject: Re: The safety expansion for FreeBSD rm(1) Message-ID: <46FB95F4.2000706@freebsd.org> In-Reply-To: <200709251800.l8PI0lof013108@lurza.secnetix.de> References: <200709251800.l8PI0lof013108@lurza.secnetix.de>
next in thread | previous in thread | raw e-mail | index | archive | help
Oliver Fromme wrote: > Daichi GOTO wrote: > > Have you any dreams that rm(1) autonomously judges target should > > be remove or not? To complexify system base command is objectionable > > behavior but adding some little and simple mechanism to prevent a > > issue is acceptable I suppose. > > I think it could cause confusion for some users or admins. > > It could also be dangerous. I remember an emergency case > when /home was an NFS mount that was dead, i.e. every > process that tried to access something in /home just hung > forever in state "D" (disk wait). During the emergency > actions on the serial console I also needed to use the > rm(1) command ... Now if it tried to read ~/.rm, it would > have drawn me mouch deeper into trouble than I already > were. :-) True, the -f option would have prevented it, > _if_ I remembered before to use it. We have realized that issue, but do not understand thats cause still now. Do you know the reason? > A common precaution against accidental rm is to establish > a snapshot rotation system. For example, create hourly > snapshots (with a cron job) and delete them automatically > after a while. So if you accidentally remove something, > you can copy it back from the latest snapshot. NetApp > Filers have such a feature built-in. You can also easily > set it up yourself with ZFS, or even with UFS snapshots, > although the latter are a bit heavyweight, IMHO. Yes. At the moment ZFS looks a best way of snapshot feature. I have heard that snapshot of UFS2 is slow under very mass files and heavy load situation. > And finally, there is chflags(1). If you know in advance > that certain files or directories must not be removed, > then "chflags schg" or "chflags uchg" them. That's the > same effect as creating a ~/.rm file with your patch. Yes. It is one of the ways :) > Another advantage of chflags(1) is that it also protects > against other kinds of damage. For example when using > shell redirection ("echo > some/important/file"), cp, dd > or other commands. In those cases chflags also offers > protection (and a snapshot would offer recovery), while > your patch only protects against rm and nothing else. > > Just my 2 cents. > > Best regards > Oliver -- Daichi GOTO, http://people.freebsd.org/~daichi
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?46FB95F4.2000706>