Subject: rc.local and rcorder(8)
To: NetBSD-current <current-users@netbsd.org>
From: Xavier HUMBERT <xavier@xavhome.fr.eu.org>
List: current-users
Date: 06/19/2002 22:57:23
rc.local claims to be "is (nearly) the last thing invoked by /etc/rc".

This is not true.

Actually, rc.local is invoked in alphabetical order, this means on a
typical server after `dhcpd`, _but before_ `named` and other important
daemons. This is really annoying, especially for the blatant case of
named, when you call wrappers for those daemons in rc.local.

This is obvious when looking at the dependancies in /etc/rc.d/local :
># REQUIRE: DAEMON
># PROVIDE: local
># BEFORE:  LOGIN

I think this can be solved in two ways :

- add a new keyword to rcorder(8), like does startup mechanism in Darwin :
#ORDER {EARLY|NORMAL|LATE}
Which rcorder should use as a primary key in crunch_file()
This is not a trivial change, but should help for other startup files.

- the (ahem) Linux way: remove /etc/rc.d/local which is imho useless
with so weak dependancies, and add `sh /etc/rc.local` at the very end
of /etc/rc. Ditto in rc.shutdown, call /etc/rc.shutdown.local _before_
rc.d files

Quick and (not so)dirty, I did it on my box.

Should I file a pr ?

Regards,

-- 
Xav
http://www.freetibet.org
http://www.tibet.fr/