What are your ‘defaults’ for your desktop Linux installations, especially when they deviate from your distros defaults? What are your reasons for this deviations?

To give you an example what I am asking for, here is my list with reasons (funnily enough, using these settings on Debian, which are AFAIK the defaults for Fedora):

  • Btrfs: I use Btrfs for transparent compression which is a game changer for my use cases and using it w/o Raid I had never trouble with corrupt data on power failures, compared to ext4.

  • ZRAM: I wrote about it somewhere else, but ZRAM transformed even my totally under-powered HP Stream 11" with 4GB Ram into a usable machine. Nowadays I don’t have swap partitions anymore and use ZRAM everywhere and it just works ™.

  • ufw: I cannot fathom why firewalls with all ports but ssh closed by default are not the default. Especially on Debian, where unconfigured services are started by default after installation, it does not make sense to me.

My next project is to slim down my Gnome desktop installation, but I guess this is quite common in the Debian community.

Before you ask: Why not Fedora? - I love Fedora, but I need something stable for work, and Fedoras recent kernels brake virtual machines for me.

Edit: Forgot to mention ufw

  • sntx
    link
    fedilink
    English
    arrow-up
    1
    ·
    1 year ago

    What is the overall goal of this build?

    There’s no overall goal to the project. It’s just the result of me tinkering with my systems from time to time (I’m allocating a bit less than three hours each day to coding on personal projects to improve my skills, some of that time flows into my nixos config).


    I am very new to nixOS and am interested in it. Specifically for ansible scripts to build out easily replicateable docker hosts for lab.

    I’ve extensively used docker/compose before I switched my systems to NixOS, since then I’ve barely touched it.

    The thing with Ansible and Docker is that you mostly define the steps you want your systems to automatically go through to reach a specific state.

    Nix[1] approaches the problem the other way around. You define the state you want to have, and Nix solves for the steps that need to be taken to reach that state.

    If you want to try your hands at that concept, I recommend installing just Nix on one of your test machines and trying out development shells/devshells with it.

    For example the SwayFX repo contains a flake.nix providing a devShell. This allows everyone working on the project to just run nix develop in the cloned repo, or nix develop github:WillPower3309/swayfx without cloning the repo to enter the development environment.

    This can be combined with tools like direnv to automatically setup development environments, based on the current directory.

    If you want a more encompassing example of what Nix can provide, take a look at:

    • nixified.ai
    • This presentation by Matthew Croughan on Nix-Flakes and Dockerfiles.

    I have also considered it for switching my primary desktop and laptops as being able to have the same OS with everything the way I like it is also intriguing.

    While I personally think NixOS is one of the most potent software in existence, and a computer without feels less capable for me, I do not recommend it easily.

    Just take a look at hlissner’s FAQ on his system config (which I greatly agree with).

    That said, I initially tried NixOS on my PC and pushed the config to a git-forge. I then installed the base NixOS ISO on my laptop and told it to build the config from git. And that worked flawlessly.

    In leaving the PC unattended for about 20mins, it went from a full Gnome desktop to my Sway setup.

    That’s the point when I was sold.


    Sorry for theate response. P.S. I love your wallpaper.

    Don’t worry about the late reponse ^^

    The wallpaper can be build with nix build sourcehut:~sntx/nix-bg#abstract-liquid btw.


    1. The “package manager” that NixOS is build around. Though I think of it more as a “build system” - not to be confused with Nix, the language the build “scripts” are written in. ↩︎

    • PipedLinkBot@feddit.rocksB
      link
      fedilink
      English
      arrow-up
      1
      ·
      1 year ago

      Here is an alternative Piped link(s):

      This

      Piped is a privacy-respecting open-source alternative frontend to YouTube.

      I’m open-source; check me out at GitHub.

    • KillSwitch10@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      edit-2
      1 year ago

      Humm good points in the articles. I think my goal of building docker hosts makes more sense. It is interesting how the took the declarative concepts of something like terraform and kubernetes and built it into an OS. It’s kind of like fedora silverblue but the two took different approaches. Perhaps fedora makes more sense on a desktop. I have a dev and DevOps background and like the idea of being able to more deeply learn Linux without having to rebuild my system from scratch when I bust it.

      Can you explain home manager? What about things to consider when installing NIX package manager on another distro?

      Perhaps figuring out how to get the wallpaper out of a nix distrobox would be a good learning experience.