From owner-freebsd-current@FreeBSD.ORG Sat Jul 19 19:40:03 2008 Return-Path: Delivered-To: freebsd-current@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 2419D1065686 for ; Sat, 19 Jul 2008 19:40:03 +0000 (UTC) (envelope-from Peter.Ross@alumni.tu-berlin.de) Received: from nschwqsrv02p.mx.bigpond.com (nschwqsrv02p.mx.bigpond.com [61.9.189.234]) by mx1.freebsd.org (Postfix) with ESMTP id 89C278FC25 for ; Sat, 19 Jul 2008 19:40:02 +0000 (UTC) (envelope-from Peter.Ross@alumni.tu-berlin.de) Received: from nschwotgx01p.mx.bigpond.com ([124.176.185.159]) by nschwmtas02p.mx.bigpond.com with ESMTP id <20080719163136.OQNI357.nschwmtas02p.mx.bigpond.com@nschwotgx01p.mx.bigpond.com> for ; Sat, 19 Jul 2008 16:31:36 +0000 Received: from oldie.bigpond.com ([124.176.185.159]) by nschwotgx01p.mx.bigpond.com with ESMTP id <20080719163134.VKUE19251.nschwotgx01p.mx.bigpond.com@oldie.bigpond.com> for ; Sat, 19 Jul 2008 16:31:34 +0000 Received: from oldie.bigpond.com (localhost [127.0.0.1]) by oldie.bigpond.com (8.14.2/8.14.2) with ESMTP id m6JGWCQC024640 for ; Sun, 20 Jul 2008 02:32:12 +1000 (EST) (envelope-from Peter.Ross@alumni.tu-berlin.de) Received: from localhost (petros@localhost) by oldie.bigpond.com (8.14.2/8.14.2/Submit) with ESMTP id m6JGWA53024637 for ; Sun, 20 Jul 2008 02:32:12 +1000 (EST) (envelope-from Peter.Ross@alumni.tu-berlin.de) X-Authentication-Warning: oldie.bigpond.com: petros owned process doing -bs Date: Sun, 20 Jul 2008 02:32:09 +1000 (EST) From: Peter Ross X-X-Sender: petros@oldie.bigpond.com To: freebsd-current@freebsd.org Message-ID: <20080720022644.H23554@oldie.bigpond.com> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII X-RPD-ScanID: Class unknown; VirusThreatLevel unknown, RefID str=0001.0A150205.488216E7.006D,ss=1,fgs=0 Subject: Re: rc improvements (wanted?) X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 19 Jul 2008 19:40:03 -0000 [Resending - maybe I used the wrong mail address which is not subscribed to -current? Does it matter? Anyway, the message did not make it to the list, it seems, and I did not get a notice.. strange] ---------- Forwarded message ---------- Date: Sun, 20 Jul 2008 01:07:32 +1000 (EST) On Sat, 19 Jul 2008, Robert Noland wrote: > On Fri, 2008-07-18 at 22:19 -0700, Doug Barton wrote: > > Bernd Walter wrote: > > > Speaking about small systems, where startup time is more a problem than > > > on 08/15 desktop and server systems. > > > What I would love to see is that scripts like moused, ypserv, lpt, etc > > > are not started if the services are disabled. > > > > That wold be a neat trick, how do you propose we accomplish it? (no, > > I'm not being snide.) > > .. > > One way you could do this is to have /etc/rc.d/active and > > /etc/rc.d/inactive (and probably an /etc/rc.d/system for critical > > stuff that most people shouldn't touch). Then you could have a > > vipw-like system to allow users to edit rc.conf that would move the > > scripts to the right directory. Of course, this would be fraught with > > potential for problems. :) > > I almost hate to toss this out there, but what about a sys v type rc? Usually the scripts are running run_rc_command. This does a checkyesno for the rcvar variable which is usually ${name}_enable. In most of the cases it uses set_rcvar to achieve this. If so, /etc/rc could evaluate ${name}_enable (it already knows them via /etc/rc.conf) before actually calling a script. There are some irregular names amongst the name of the rcvar variable. I am not 100% sure whether same of the scripts set ${name}_enable vaiables implicitly. That could complicate things. I could not find evidence by browsing through them. I also do not know whether there are scripts that actually do something valuable before calling run_rc_command. At the moment it looks to me that these excemptions could be dealt with by adapting the scripts so they meet the standard (running only when ${name}_enable is set). I only looked through some of the /etc/rc.d scripts en detail (+ some greps for rcvar etc. in the directory) so it needs some more investigation. If it works it avoids messing around with symlinks or moving scripts around, and it reduces the scripts that actually run. As a sys admin I really like the BSD way of having everything relevant to my system in one /etc/rc.conf. It is very convenient. Regards Peter