Re: [CFT] packaging the base system with pkg(8)

From: David Chisnall <theraven_at_FreeBSD.org>
Date: Tue, 19 Apr 2016 08:54:48 +0100
On 19 Apr 2016, at 08:44, Julian Elischer <julian_at_freebsd.org> wrote:
> 
>> All this can be done by meta-packages which depend on larger package groups.
> Currently Metapackage is a way to make 10 packages look like 11 packages.  The framework needs to understand to hide the 10 internal packages if they are part of a metapackage.

I agree, and patches to do this are very welcome.  Currently, pkg is short of contributors.

I see basically three use cases for a packaged base:

1) People wanting a FreeBSD install to use as a server or workstation.  These people will install the FreeBSD 11 metapackage and not care that it is a few hundred MBs.  It would be nice if the pkg tool could present this as a single package in list views, but that’s a UI issue with pkg, not an issue with the number of packages in the base system.

2) People wanting to install embedded systems.  Anyone who has tried to run FreeBSD on a system with a small amount of flash storage will have encountered the pain of having to use some kind of ad-hoc update.  Being able to manage updates to these systems with the same packaging tool as you manage big systems is a big improvement.

3) People wanting to install service jails (sorry, containerised applications).  These want the smallest possible attack surface and so want the smallest amount of the base system that they can have.  Here, small packages are an advantage.  It will take a little while for ports to learn enough about the granularity of the base system for this to really be useful, but it would be great to be able to install nginx, for example, in a jail and have only the handful of libraries that it needs.

The big advantage of going with small packages initially, however, is that it will allow us to get some data on what the correct groupings are.  If we have large packages, then it’s very hard to tell which subsets of the packages people want.  That’s exactly the situation that we’re in now: we know some people don’t want docs or games, but that’s about all that we know.  It’s easy to move to a model where we have *fewer* packages in the future, but it’s harder to split them.  That also applies to dependencies.  If I know that a port depends on the shell, then it’s easy to update it from depending on a sh package to depending on a core system utilities package automatically, but it’s very hard to do an automatic update in the other direction.

David
Received on Tue Apr 19 2016 - 05:55:12 UTC

This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:41:04 UTC