From owner-freebsd-hackers@freebsd.org Tue Mar 13 18:50:57 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 E8EF0F4156C for ; Tue, 13 Mar 2018 18:50:56 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from kib.kiev.ua (kib.kiev.ua [IPv6:2001:470:d5e7:1::1]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 551AA6EAD4 for ; Tue, 13 Mar 2018 18:50:56 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from tom.home (kib@localhost [127.0.0.1]) by kib.kiev.ua (8.15.2/8.15.2) with ESMTPS id w2DIojbe099256 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Tue, 13 Mar 2018 20:50:48 +0200 (EET) (envelope-from kostikbel@gmail.com) DKIM-Filter: OpenDKIM Filter v2.10.3 kib.kiev.ua w2DIojbe099256 Received: (from kostik@localhost) by tom.home (8.15.2/8.15.2/Submit) id w2DIoiFe099252; Tue, 13 Mar 2018 20:50:45 +0200 (EET) (envelope-from kostikbel@gmail.com) X-Authentication-Warning: tom.home: kostik set sender to kostikbel@gmail.com using -f Date: Tue, 13 Mar 2018 20:50:44 +0200 From: Konstantin Belousov To: Theron Cc: freebsd-hackers@freebsd.org Subject: Re: GSoC Idea: per-process filesystem namespaces for FreeBSD Message-ID: <20180313185044.GQ76926@kib.kiev.ua> References: MIME-Version: 1.0 Content-Type: text/plain; charset=koi8-r Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: User-Agent: Mutt/1.9.4 (2018-02-28) X-Spam-Status: No, score=-2.0 required=5.0 tests=ALL_TRUSTED,BAYES_00, DKIM_ADSP_CUSTOM_MED,FREEMAIL_FROM,NML_ADSP_CUSTOM_MED autolearn=no autolearn_force=no version=3.4.1 X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on tom.home X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.25 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 13 Mar 2018 18:50:57 -0000 On Tue, Mar 13, 2018 at 12:53:18PM -0400, Theron wrote: > Hello All, > > I am an undergraduate a Boston University looking to contribute to > FreeBSD this summer under GSoC. > > The idea I would like to implement is to bring to FreeBSD a per-process > mounting / namespaces functionality similar to that of the Plan9 > operating system as a means to give greater flexibility in combination > with less overhead than is associated with chroots and jails for > purposes of isolating software setups from one another and from the > underlying system. > > For those unfamiliar with Plan9, here is a rough explanation of the > namespace feature: unlike in Unix, where all processes share the same > virtual filesystem, each process instead has its own view of the > filesystem according to what has been mounted, which, unlike Unix mount, > as an unpriviliged operation changing only what is seen by the > particular process and any processes it later spawns.š Thus it is > possible for one process's /bin to be completely different from another > process's /bin, and neither need be the same as the system's /bin, > should one exist. > > As an example of its application and potential usefulness, a user may > mount on top of /usr/local an overlay pointing to a location owned by > the user, allowing existing binary packages which expect a /usr/local > PREFIX to be installed and run without any modification either to the > binary packages or to the underlying system.š Currently the only ways to Do you understand what consequences of this feature is, when mixed with setuid ? > achieve this are by recompiling ports with a different PREFIX or by > configuring a jail.š Some, but not all, programs will function > out-of-place under tweaked PATH and LD_LIBRARY_PATH, but this is not a > general solution and leads to messy environments. > > Although I have not previously worked with kernel programming in > particular, I have good experience of high-level practices and low-level > details of C programming and I can teach myself new technical details > quickly.š In researching how to approach the task, I will study the > existing implementation of chroot, jail, and fdescfs as examples of > process-specific namespace behavior already supported in FreeBSD > kernel.š The nullfs and unionfs may also serve as work to build off of, > although unionfs as currently implemented appears to be partially broken. > > Robustness of the implementation allowing, it should eventually be > possible to replace system directories /bin, /sbin, /etc, etc. with > bindings configured at boot time to improve the safety of live system > upgrades and to provide a means of returning to older configurations > which is not dependent on filesystem-specific snapshotting features. > > Although per-process filesystem namespacing is unconventional in the > face of the dominant Unix single-namespace model, introducing the > feature to a Unix-like system does not constitute a radical change, as > it is compatible with and indeed facilitates the meeting of the > reasonable expectation of existing and unmodified software to find > resources in predetermined file paths. > > My attempt here to outline the relevant concepts is to the best of my > limited understanding.š Hopefully I am not creating or propagating any > misinformation and have not grossly misassessed the complexity of the task. > > I would greatly appreciate any suggestions of approaches to this task > and of who to contact for more expertise and for potential mentorship. You need to understand a lot about the FreeBSD VFS to sketch the approach for implementation. I do not want to sound sceptical, but the amount of architectural work, and then the quantity of the details to discover and handle for this project certainly exceed the scope of GSoC. If you can formulate the basic ideas of the possible implementation, this might add more substance to the discussion.