LFS-RPM/README.md
YellowJacketLinux 413556fd3a
Docfix document updates (#10)
* spell check

* Prep for new README

* Work on the new README

* FHS notes added

* tweaks

* GLibC bootstrap subversion etc.

* layers

* not needed

* work on layers

* rename

* layers work

* rename multilib

* rename again

* more file renaming

* stuff

* link fixes etc.

* cleaning up a bit

* spell fixes etc.

* nuke un-needed

* fips note

* spellfix

* started TOS

* ToC work
2023-04-28 03:08:59 -07:00

7.8 KiB
Raw Blame History

YellowJacket GNU/Linux (YJL)

YellowJacket GNU/Linux is currently a personal GNU/Linux distribution that is based upon Linux From Scratch 11.3 built using CentOS 7.9.2009 as the build host.

When an installer is ready, I will welcome contributors to this project but if it never becomes popular, I will still use and maintain it myself.

The purpose of YJL is to be a desktop distribution for hobbyists. Commercial Enterprise GNU/Linux is of no interest for this project.

If you want to read what motivated this, see The Why

  1. Versioning Scheme
  2. Kernel Package
  3. GNU C Library (GLibC)
  4. GNU Compiler Collection (GCC)
  5. Perl5
  6. Python3
  7. Python2
  8. TLS Stack
  9. Filesystem
  10. Package Management
  11. Repository Layers

Versioning Scheme

YJL will use LTS kernels allowing longevity of a release without the expense of a kernel engineer to back-port kernel patches yet still retain a stable kernel API for the release.

Thus, it is logical to me to give a YJL release the same version as the LTS kernel it ships with.

If I had an installer now, it would thus be:

Yellow Jacket GNU/Linux 6.1

to indicate the Linux 6.1 series kernel is shipped with it.

GLibC Subversion

YJL will have a subversion referencing the version of GLibC used for the build. The subversion will be referenced in the /etc/yjl-release tag.

If I had an installer now, that file would thus contain:

Yellow Jacket GNU/Linux 6.1 (GLibC 2.37)

Kernel Package

YJL will provide vanilla kernel packages (I do not intend to provide patched kernels) but I also hope to create a system by which a user can download GPG signed kernel configuration files tailored to their hardware (say, a particular NUC series) and the GPG signed kernel source and build customized kernel packages on their system with little technical experience required.

Kernels will be vanilla LTS kernels and updates will be fron the same kernel series.

The Philosophy

When a given LTS kernel provides what a user needs, that user should not have to upgrade their install to a completely new version that may do things quite differently (like the SystemV to SystemD init upgrade, X11 to Wayland, etc.) just to have a system that has modern libraries and programs.

An upgrade of YJL to a newer LTS kernel does not mean there will be major structural updates to how YJL works, but if there are, that is when they will happen.

Of course a user can install a newer kernel (even non-LTS) if they so choose and/or need features of a newer kernel but do not want the structural changes of a newer YJL.

GNU C Library (GLibC)

Every time a new stable version of GLibC is released (about every six months) another bootstrap of YJL will take place using the new GLibC.

Once all packages are built and a testing period has been performed, the new subversion will be released as an update to the old previous subversion thus allowing the update to take place.

GNU Compiler Collection (GCC)

YJL will use the Current Stable version of GCC when the bootstrap takes place. Point release updates of GCC (e.g. GCC 12.2.0 to 12.2.1) will be made available as updates. Major version updates (e.g. 12.2.x to 12.3.x) would have to take place at the next GLibC bootstrap.

The YJL GCC packaging will always include the c,c++,ada, and d compilers that are required to build newer versions of themselves. FORTRAN, Go, and Objc/Objc++ will be made available except for in the 1.core package repository.

Older versions of GCC may be made available in /opt/legacy but will only provide c/c++ compilers if made available.

Perl5

YJL will use the Current Stable version of Perl5 when the bootstrap takes place. Point release updates of Perl5 (e.g. 5.36.0 to 5.36.1) will be made available as updates. Major updates to Perl5 (e.g. 5.36.x to 5.38.x) would have to take place at the next GLibC bootstrap.

Python3

YJL will use the Current Stable version of Python3 when the bootstrap takes place. Point releases of Python3 (e.g. Python 3.11.2 to 3.11.3) will be made available as updates. Major updates to Python3 (e.g. 3.11.x to 3.12.x) would have to take place at the next GLibC bootstrap.

Python2

Python2 is an expired environment but there still are legitimate reasons to have it for some users.

The last version of Python2, with some security patches, will be available in an optional add-on repository.

It will install into /opt/legacy/python2 as the install prefix. Scripts that call Python2 should call it using the shebang:

#!/usr/bin/env python2

The user calling it will of course have to have the appropriate path.

Some add-on modules will be built for it as need arises.

TLS Stack

GnuTLS will be the default system TLS stack. Any software that needs a TLS stack that can be built against GnuTLS will be built against GnuTLS.

GnuTLS will not be built with the OpenSSL API compatibility layer.

LibreSSL

For software (including kmod) that needs the OpenSSL API, LibreSSL will be used where the OpenSSL API provided by LibreSSL is sufficient.

LibreSSL will be installed in such a way as to allow a parallel install of OpenSSL for cases where the OpenSSL API is needed but newer than the OpenSSL API provided by LibreSSL.

OpenSSL

OpenSSL will be provided for software that needs the OpenSSL API for which LibreSSL is not sufficient.

FIPS Note

YJL has zero interest in FIPS Compliance

See LibreSSL Portable Issue 572

FIPS compliance does not make a system more secure, it only means there is a means by which to invoke a subset of approved cryptographic functions that meet a standard defined in a board room, some of which have not aged very well and should not be used.

If you are obligated to FIPS compliance, use something else, or create a custom repository with a FIPS-mode OpenSSL and rebuild all TLS related packages to link against it.

Filesystem

YJL will follow the FHS 3.0 specification.

Despite being a 64-bit operating system, LFS will use /{,usr/}lib for libraries rather than the /{,usr/}lib64 that the majority of 64-bit x86_64 Linux distributions use.

There are plans for multilib support, but done differently than most distributions do it.

For more information, see FHS-Note and Multilib-Note.

Package Management

YJL will use the RPM Package Manager for package management.

RPM was chosen because I have a lot of personal experience with it, not because it is inherently better than other available options.

Repository Layers

“Ogres are like onions. Onions have layers. Ogres have have layers. Onions have layers. You get it? We both have layers.” --- Shrek

Unlike distributions that try to package everything under the sun, YJL will provide a solid core that groups of users with a particular interest or need can build on top of---even replacing packages in the solid core if their specialist need requires it.

See Repository-Macro for more information on how this layering system would work.

Packaging guidelines will need to be written. Some of this has been started: