From owner-freebsd-hackers@freebsd.org Wed Dec 19 16:26:14 2018 Return-Path: Delivered-To: freebsd-hackers@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id C7665133B7BB for ; Wed, 19 Dec 2018 16:26:14 +0000 (UTC) (envelope-from debdrup@gmail.com) Received: from mail-lj1-x242.google.com (mail-lj1-x242.google.com [IPv6:2a00:1450:4864:20::242]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 5C43A88383 for ; Wed, 19 Dec 2018 16:26:13 +0000 (UTC) (envelope-from debdrup@gmail.com) Received: by mail-lj1-x242.google.com with SMTP id s5-v6so17909315ljd.12 for ; Wed, 19 Dec 2018 08:26:13 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :content-transfer-encoding; bh=ogNLeleXU11sT2d13VBHfTtqhXlBmcQxPIonJZime6A=; b=nienwFyfgSc5L3niWWQw+nw81hj9fMlAJSL1vB1AP6W45YHKks1BQpsZYcO+VTpI/X plnPYKrwT55e60dkq7z+01WgpThtKGdfRazcznJtReJO6ekE0dSeLKPuLOTaBG+wIpiH 95pF5sThN7B9Nwz8FKIOzS7Z9QfQrDi1hwW+IuI2UkBL1aNd9QETomCAoNUpgRTmMgff nR/3wv6UFDGm6IRjW/AsVx3sG9+kkmK4nqpm1hqCvmXgCWU8xaDrs6mwluMbQsDGs2W9 iH1lmhxSr6o3FPFP4tVDFkbmUA75/EzWSwEgWnKmUyzouFSvpjW+NGv58bCqVDQTaKxH peCQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:content-transfer-encoding; bh=ogNLeleXU11sT2d13VBHfTtqhXlBmcQxPIonJZime6A=; b=rnfF4MyxsKMrZwHqGTN3sg+LQnnDFozE5tkGo7tS0598M0GpY8B0a7oRAZXmrmieoz 6wlC2cjrnzPpLYDjJKElaKpr9FTEpi0BDrc/QMwnlp94pe2nxCF4pixhE74kuzB0Umke pTuZmpGZzUsPxfqsGcGHRdliKuxXb1UleeAg7fhvPG0FCOCgYFe5ny4iL9A+2WvFAM8B b3MeWPhRqIRYQoqi9jrR4BBC4KrAum8degyS3akdslCvkwWj6bv6LY+c5xnu7ai67Yhz o6ojQB1k6aCLoUUb5tU1lTgnx6sp6yXTk8huJVZCfnAP2Vy/AQGq8qkRg5gB1x2kUnf7 tVMA== X-Gm-Message-State: AA+aEWZZ98YeWWua9CmAsQiwc61rgErMAhOYrQn6Kc9y+V6/WusRkNTI JAfHgPcOCXnuJWxxQfclxZNZup/RJIHOm0H0zz58fA== X-Google-Smtp-Source: AFSGD/WITf4WKsTWMCt8z8/k8QkQeB+Ku3qvzUBlk6u7EorMN03zjRv8dVNZKM6b89bYhF32WmxkxjjP2aQVP6JTJQA= X-Received: by 2002:a2e:630a:: with SMTP id x10-v6mr12538071ljb.11.1545236771304; Wed, 19 Dec 2018 08:26:11 -0800 (PST) MIME-Version: 1.0 Received: by 2002:a2e:165d:0:0:0:0:0 with HTTP; Wed, 19 Dec 2018 08:26:10 -0800 (PST) In-Reply-To: <397FBAFF-2575-4AE4-B2BC-2DFDA769040A@FreeBSD.org> References: <397FBAFF-2575-4AE4-B2BC-2DFDA769040A@FreeBSD.org> From: "D. Ebdrup" Date: Wed, 19 Dec 2018 17:26:10 +0100 Message-ID: Subject: Re: OpenRC on FreeBSD To: freebsd-hackers Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Rspamd-Queue-Id: 5C43A88383 X-Spamd-Bar: --- Authentication-Results: mx1.freebsd.org; dkim=pass header.d=gmail.com header.s=20161025 header.b=nienwFyf; dmarc=pass (policy=none) header.from=gmail.com; spf=pass (mx1.freebsd.org: domain of debdrup@gmail.com designates 2a00:1450:4864:20::242 as permitted sender) smtp.mailfrom=debdrup@gmail.com X-Spamd-Result: default: False [-3.45 / 15.00]; ARC_NA(0.00)[]; NEURAL_HAM_MEDIUM(-0.97)[-0.971,0]; R_DKIM_ALLOW(-0.20)[gmail.com:s=20161025]; FROM_HAS_DN(0.00)[]; R_SPF_ALLOW(-0.20)[+ip6:2a00:1450:4000::/36]; FREEMAIL_FROM(0.00)[gmail.com]; MIME_GOOD(-0.10)[text/plain]; PREVIOUSLY_DELIVERED(0.00)[freebsd-hackers@freebsd.org]; NEURAL_HAM_LONG(-0.90)[-0.904,0]; RCPT_COUNT_ONE(0.00)[1]; RCVD_COUNT_THREE(0.00)[3]; IP_SCORE(0.04)[ip: (3.26), ipnet: 2a00:1450::/32(-1.59), asn: 15169(-1.39), country: US(-0.08)]; TO_DN_ALL(0.00)[]; MX_GOOD(-0.01)[cached: alt3.gmail-smtp-in.l.google.com]; DKIM_TRACE(0.00)[gmail.com:+]; DMARC_POLICY_ALLOW(-0.50)[gmail.com,none]; RCVD_IN_DNSWL_NONE(0.00)[2.4.2.0.0.0.0.0.0.0.0.0.0.0.0.0.0.2.0.0.4.6.8.4.0.5.4.1.0.0.a.2.list.dnswl.org : 127.0.5.0]; TO_MATCH_ENVRCPT_ALL(0.00)[]; NEURAL_HAM_SHORT(-0.61)[-0.607,0]; FROM_EQ_ENVFROM(0.00)[]; MIME_TRACE(0.00)[0:+]; FREEMAIL_ENVFROM(0.00)[gmail.com]; ASN(0.00)[asn:15169, ipnet:2a00:1450::/32, country:US]; RCVD_TLS_LAST(0.00)[]; DWL_DNSWL_NONE(0.00)[gmail.com.dwl.dnswl.org : 127.0.5.0] X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 19 Dec 2018 16:26:15 -0000 On 12/19/18, Martin Wilke wrote: > Hi > > I'd like to reopen the discussion for OpenRC on FreeBSD. Basically this i= s > the second attempt to get it into FreeBSD. > > I've opened a review here with a working patch for CURRENT, > https://reviews.freebsd.org/D18578 > > > To recap the discussion > * First attempt of RFC in March of 2018: > https://lists.freebsd.org/pipermail/freebsd-hackers/2018-March/052358.htm= l > * Working group at BSDCan: > https://wiki.freebsd.org/DevSummit/201806/OpenRC > > Here some key points: > > OpenRC provides additional features for service management without requir= ing > kernel changes or replacing pid 1, unlike launchd and other solutions. A= ll > rc.d scripts have been converted with a few changes, typically changing t= he > shebang and making sure the start function is named start(). Most service > scripts are simplified, usually needing only name, command, and, if > required, depends statements. > > History: > OpenRC started out as an init system by Roy Marples, developed for the > Gentoo Alt (FreeBSD) kernel branch. It was more widely adopted into Gento= o > as baselayout v2, and was then split off as a separate BSD-licensed proje= ct. > It is under active development, portable, and remains BSD licensed today. > > OpenRC and RC: > Both can coexist and be chosen with a setting in /boot/loader.conf. > > OpenRC Features: > > Service supervision and service monitoring: any service can be supervised= . > Supervised services that crash are automatically restarted. The rc-status > command shows how many times a service has restarted. > > Device hotplug support and event-driven service management: the hotplug > feature allows devd to take actions when devices are connected. For examp= le, > a USB wifi adapter can create additional network services when attached. = The > net-online service can, for example, detect when a network connection is > restored, and restart ntp. > > Network profiles: using stacked runlevels, different profiles can be > established for different networking settings. For instance, different > profiles can be used for wired or wireless networking, or for differing > wireless networks, as well as dependency caching and parallel startup spe= ed > up booting. > > Interactive mode: > The boot process can be run interactively for more effective debugging. > > OpenRC uses the term =E2=80=9Crunlevels=E2=80=9D to refer to the context = in which a script > is running. There are only three at present: > sysinit (the OpenRC system is starting), boot (start base services when t= he > computer is booting), and default (normal execution). > > OpenRC, by default, provides a =E2=80=9Ccolorized=E2=80=9D text boot, usi= ng ANSI color > sequences. This can be disabled. > > Ports: > As of July 2017, iXsystems has created OpenRC versions of port service > scripts for the entire ports tree. These scripts coexist with the rc.d > versions. > > License: > OpenRC is a BSD licensed RC init system written in C. From a user > perspective, it is very similar to the FreeBSD rc.d init system, making i= t > easy to use and learn. > > Tested: OpenRC has been used as the init system for TrueOS since October > 2016. > > Ken Moore has an OpenRC vs RC.d comparison which can be found here: > http://www.wonkity.com/~wblock/openrc/OpenRC_rc.d.pdf > > I look forward to discuss the features and capabilities of OpenRC. > > Regards, > Martin > > _______________________________________________ > freebsd-hackers@freebsd.org mailing list > https://lists.freebsd.org/mailman/listinfo/freebsd-hackers > To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@freebsd.org= " > You mention parallel service startup as an advantage of OpenRC, but to the best of my knowledge it is turned off by default everywhere, and there's no actual guarentee that parallel service startup won't randomly break. Indeed, there are two outstanding bugs for this very issue, [1] has been open/connfirmed since 2011 and [2] has been open/with nobody assigned since 2014 - neither of them seem to be fixed, from what I can tell? It seems to me that if this is indeed a feature that people want (and I can see why, if you're starting a few hundred jails with only few inter-dependencies) - but I feel sure that people won't want it if it means that the system will no longer boot reliably. So what I'm really asking for, rather than not enabling parallel startup by default (despite this being what most projects apppear to have done), can the problem be fixed before OpenRC is in FreeBSD, such that FreeBSD can have parallel startup that reliably works? I wish I had the talent to contribute in any meaningful way, but I'm just a sysadmin and as a coder I'm a pretty poor florist. [1]: https://bugs.gentoo.org/391945 [2]: https://github.com/OpenRC/openrc/pull/12 --=20 Daniel Ebdrup aka. D. Ebdrup.