Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Post History

50%
+0 −0
Q&A What's the "big picture" of how my operating system is put together?

This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro. Systemd manages most of the stack these...

posted 7mo ago by matthewsnyder‭  ·  edited 7mo ago by matthewsnyder‭

Answer
#6: Post edited by user avatar matthewsnyder‭ · 2024-06-19T21:29:20Z (7 months ago)
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a variant Linux kernel. Switching to a non-Linux kernel is harder and you're better off just installing something that comes with the kernel you want, like BSD.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with its own Web UI.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consistent is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a variant Linux kernel. Switching to a non-Linux kernel is harder and you're better off just installing something that comes with the kernel you want, like BSD.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with its own Web UI.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consistent is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has [a lot](https://wiki.archlinux.org/title/Installation_guide) more [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
#5: Post edited by user avatar matthewsnyder‭ · 2024-06-19T21:28:47Z (7 months ago)
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a variant Linux kernel. Switching to a non-Linux kernel is harder and you're better off just installing something that comes with the kernel you want, like BSD.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with its own Web UI.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a variant Linux kernel. Switching to a non-Linux kernel is harder and you're better off just installing something that comes with the kernel you want, like BSD.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with its own Web UI.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consistent is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
#4: Post edited by user avatar matthewsnyder‭ · 2024-06-19T21:27:27Z (7 months ago)
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a variant Linux kernel. Switching to a non-Linux kernel is harder and you're better off just installing something that comes with the kernel you want, like BSD.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with a website it serves at localhost:631 for managing your printers.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a variant Linux kernel. Switching to a non-Linux kernel is harder and you're better off just installing something that comes with the kernel you want, like BSD.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with its own Web UI.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
#3: Post edited by user avatar matthewsnyder‭ · 2024-06-19T21:24:11Z (7 months ago)
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a non-Linux kernel, but it's a lot of work in practice and you're better off just installing something that comes with the kernel you want, like BSD. But if you would be satisfied with compiling a customized variant of the Linux kernel, that should be pretty easy to drop in.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with a website it serves at localhost:631 for managing your printers.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a variant Linux kernel. Switching to a non-Linux kernel is harder and you're better off just installing something that comes with the kernel you want, like BSD.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with a website it serves at localhost:631 for managing your printers.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
#2: Post edited by user avatar matthewsnyder‭ · 2024-06-19T21:23:13Z (7 months ago)
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a non-Linux kernel, but it's a lot of work in practice and you're better off just installing something that comes with the kernel you want, like BSD. But if you can compile a customized variant of the Linux kernel, that should be pretty easy to drop in.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with a website it serves at localhost:631 for managing your printers.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
  • This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.
  • Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a non-Linux kernel, but it's a lot of work in practice and you're better off just installing something that comes with the kernel you want, like BSD. But if you would be satisfied with compiling a customized variant of the Linux kernel, that should be pretty easy to drop in.
  • Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).
  • Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order.
  • The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.
  • A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.
  • Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with a website it serves at localhost:631 for managing your printers.
  • Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.
  • The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.
  • Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.
  • If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.
#1: Initial revision by user avatar matthewsnyder‭ · 2024-06-19T21:22:14Z (7 months ago)
This varies because, being modular, Linux will have different components according to what it's used for. I'll write mainly for a mainstream desktop distro.

Systemd manages most of the stack these days. At boot, kernel and systemd are started automatically. You can replace the kernel with a non-Linux kernel, but it's a lot of work in practice and you're better off just installing something that comes with the kernel you want, like BSD. But if you can compile a customized variant of the Linux kernel, that should be pretty easy to drop in.

Systemd is a recent thing, which is controversial for going against the Unix philosophy you mention. It's a fairly ambitious init system, service manager, device manager, domain resolver... The list keeps growing. Due to this it's getting harder every day to drop-in replace systemd if you don't like it. A much easier option is to start with a [non-systemd-distro](https://linux.codidact.com/posts/291778).

Each type of hardware has some services associated with it. Systemd (or its equivalents) will start these in some logical order. 

The most interesting one is graphics: Systemd will start the display manager so that you can have the login GUI. When you do login, the display manager will start a graphics server (X11 or Wayland) and window manager/desktop environment so you get your taskbar, tray icons, etc. Part of the graphics server's functions is handling input from mouse and keyboard.

A "desktop environment" is actually just a kludge of disparate software. Some of it, like the title bar and window manager, go together somewhat. Others, like browser and mail client, make little sense to bundle in but the DEs do because they think it will help them acquire lazy users. Importantly, the way windows behave (maximizing/minimizing, multiple desktops, automatic layouts) is governed by a component of the DE called a window manager, and if you poke a bit you can usually replace the window manager in DEs like KDE/Plasma (this very popular DE is officially renamed to Plasma now, but it's a stupid name with poor searchability; the old name was KDE). You can install multiple DEs and swap them, but there may or may not be some added hassle from dealing with their bundled programs - for example, Kmail is a bit temperamental when used outside KDE because there's some over-coupling with common KDE components like akonadi, that don't make sense if you're not using KDE.

Sound system, networking, bluetooth, printing etc. are also going to have their own services started by systemd. Sometimes the systems don't have a UI, or just a simple CLI, and you install a separate utility to actually interact with it. For example, for sound you'll have some combination of alsa, pulseaudio, pipewire, jack etc. But the nifty GUI for changing your volume with the tray icon could be a program like pavucontrol, or an equivalent that's bundled into something like KDE/Plasma. By contrast, for printing people use CUPS, which already comes with a website it serves at localhost:631 for managing your printers.

Then you have all the "user programs" like browser, editor, etc. Unlike the services, these get started on demand. The developers will usually make them distro-agnostic so that they can run on any Linux (some distros like Debian like to customize them when adding as a package). You can obviously mix and match to your heart's content. Notably, most Linux GUI programs use some common GUI toolkit like GTK or Qt. This will give them a common look and feel (eg. buttons). But if for example you install a Qt program on a system that's been all GTK up to that point, you may be surprised that its UI looks ugly and inconsistent. Usually, each graphics toolkit will have its own configuration & theming utility, which you can install separately to make it look nicer, but making them consisting is largely a manual task.

The main way to install software is the package manager, which is actually what defines the distro. You can install different package managers, but it's usually easier to just use the default one where you can, and if you don't like it, install the distro that comes with the one you want. That said, for example flatpak uses a completely parallel way to install programs, so it's normal to use flatpak along with the default system package manager. Guix is designed to play nice as a second manager too.

Arch Linux is designed around having a very simple install that sets up the bare minimum needed to get a console running, so that everything else can be separately set up by the user according to their needs. The Arch wiki has a lot [more](https://wiki.archlinux.org/title/Installation_guide) [information](https://wiki.archlinux.org/title/General_recommendations) about the specifics.

If you want to go even more low-level, https://www.linuxfromscratch.org/ is a great resource.