Why I love FreeBSD

(it-notes.dragas.net)

242 points | by enz 8 hours ago ago

83 comments

  • krylon 4 hours ago

    My home server has been running FreeBSD for ten years now, and it has never let me down. Except for one time I got fresh with /dev/speaker and triggered a spontaneous reboot (I don't know if it's FreeBSD's fault or the hardware, though).

    I delayed upgrading to 15.0 after it was released, but last weekend I finally did it, and it left me wondering why I hadn't done it sooner, because it went quickly and smoothly.

    Is there anything FreeBSD can do that, say, Debian cannot? Probably not (at least I cannot think of anything). When I set up the server, ZFS was a huge selling point, but I heard that it works quite well on Linux, these days. But I appreciate the reliability, the good documentation, the community (when I need help).

    • zenoprax 3 hours ago

      > Is there anything FreeBSD can do that, say, Debian cannot?

      If you asked the opposite (what can Debian do that FreeBSD cannot) I would have more to say and it would mostly be preceded by "I know FreeBSD is not Linux but ...". Whenever I need to do any sort of maintenance or inspection I have to look up the equivalent commands for things like `lsblk` and something nested in `/usr/etc/...` when I'm used to finding it in `/etc/` over every other system.

      This is a consequence of both FreeBSD's reliability in needing very infrequent attention and my limited use-cases to use it. As a NAS it is great but I can't touch it without full-text search of all my notes on the side! Either way, no regrets about learning and relying on it after ~18 months so far.

      • atmosx an hour ago

        Lack of docker support? Docker is available on macOS through emulation yes but bhyve is a thing… so why not? :-)

    • MisterTea 4 hours ago

      ZFS on FreeBSD is first class. I had an old FreeNAS raid z5 array on 5x 500GB disks that I wanted to check 4 years after decommissioning the system. I put together a temporary machine with all the disks plugged in and without doing anything the live FreeBSD image found and configured the array. I was instantly able to look through the file system and even dump it to my current FreeBSD server with almost 0 effort. I was sold after that. These days I prefer to run small systems and basic services. I don't want webguis or docker images anymore.

      • adiabatichottub an hour ago

        Right. On my development workstation I use Arch and I'm always worried a kernel upgrade is going to break the ZFS module. For those that aren't familiar, ZFS isn't part of mainline Linux because of licensing incompatibility (and general distrust of Oracle).

        On FreeBSD I know its always going to work.

    • atmosx an hour ago

      > Is there anything FreeBSD can do that, say, Debian cannot?

      Yes. Emulate traffic latency using IPFW and dummynet[^1]. There is no Linux (or OpenBSD, NetBSD) counterpart.

      The ZFS implementation is less buggy.

      [^1]: https://man.freebsd.org/cgi/man.cgi?dummynet

    • evanjrowley 4 hours ago

      >Is there anything FreeBSD can do that, say, Debian cannot?

      ZFS boot environments.

      One could install Debian's root on ZFS by following the OpenZFS documentation guide, combine it with ZFSBootMenu (or similar), but there won't be any upstream support from the Debian project itself.

      The Nitrux Linux distribution is based on Debian and provides an immutable feature similar to boot environments, but you can't treat your immutable boot images the same way you can treat your mutable data like how you can with ZFS datasets on FreeBSD.

      • sidkshatriya 3 hours ago

        you can use snapper + btrfs and the end result is like `bectl`. However it not as simple/integrated as ZFS Boot environments on FreeBSD

        • krylon 3 hours ago

          On openSUSE Tumbleweed, it is. Each Upgrade creates two snapshots, one before, one after, and if anything goes wrong, I can boot into a snapshot where the world was still in order.

          I have a higher opinion of ZFS than I do of btrfs, but FWIW snapper+btrfs has worked well for me on openSUSE Tumbleweed for ten years now, too.

        • shrubble 3 hours ago

          The btrfs code quality seems less than ZFS, based on the reports I have read.

          • krylon 10 minutes ago

            Last I heard (~8 years ago), the RAID-like functionality in btrfs was very unstable and crash-prone. The impression I got was that there was not a lot of interest in fixing this. Then bcachefs came and ... appears to have gone nowhere AFAICT.

            The non-RAID part of btrfs appears to be stable. It's the default filesystem on openSUSE and SLES. But I don't think it's ever going to reach feature parity with ZFS.

          • sidkshatriya 18 minutes ago

            btrfs is suffering from a lot of old bad publicity and some poor design decisions around RAID.

            But by now it is a great file system if you don't go near RAID5/6. btrfs has its flaws (ZFS has its own flaws!). However:

            - It's used a lot, especially by facebook and Redhat (on fedora)

            - Gets a lot of testing

            - Sees a lot of bug fixes

            - Has a lot of features

            I haven't read btrfs code but given that it is a popular file system and Linux code quality tends to be good in popular subsystems I would hesitate to say its code quality is worse than ZFS in any way.

    • toast0 4 hours ago

      > Is there anything FreeBSD can do that, say, Debian cannot? Probably not (at least I cannot think of anything).

      Stability of user interface and documentation.

      • throwaway27448 3 hours ago

        What documentation does a distro even publish? I only ask because freebsd has the most solid documentation I've used of any OS I've ever encountered. I seriously doubt Debian has documented the linux kernel that well (which, tbf, would be an insane project to even attempt)

        • adiabatichottub an hour ago

          I've been surprised at times by what's missing. There are are some strange omissions, from most recent memory around the Bourne shell builtin commands and make(1). I've had to go hunting in other BSD distribution manuals at times to find what I need. I'd say the GNU core utilities sometimes have better docs for their equivalent commands.

          That said, for non-core utilities on Linux it's pretty hit-or-miss. The BSDs are generally pretty consistent in what they do offer, and that's what I love about them. Of course it's a different development model and it shows.

        • toast0 3 hours ago

          Debian has an installation guide[1]. I'd imagine all the major distributions do.

          But it probably has to change a lot for every major release, because so many things change. FreeBSD major releases have changes too, but a lot of the user interfaces are very stable and so the documentation can be too. Stable documentation allows time for it to be edited and revised to become better documentation, as well as developing quality translations.

          [1] https://www.debian.org/releases/stable/amd64/

    • whizzter 4 hours ago

      My current home server passed 10 years in the autnum, but I've been running FreeBSD on servers since around 2000.

      The main gripe is probably Docker and/or software depending on Linux-isms that can't be run natively without resorting to bhyve or smth alike that.

      • jbverschoor an hour ago

        Exactly the reason why I switched from FreeBSD to Debian, 25 years ago

      • BirAdam 4 hours ago

        You could just use podman.

        • whizzter 3 hours ago

          Theoretically yes, however still limited by how well the FreeBSD Linux layer handles syscalls. A year or so back I tried running .NET (just binaries, not via a container) since the port wasn't as far along as today and it crashed due to what I suspect was slight differences in signal handling defaults.

          And this is part of the situation that's going to get worse, io_uring will become more popular in language runtimes and iirc it's not trivial to emulate via existing FreeBSD mechanisms (kqueue).

          Iirc Mac docker uses xhyve (bhyve port/inspired) to run containers via Linux emulation, MS went for pv-Linux for WSL2, while FreeBSD has been "good enough" so far.

          But I think that for containers it's either time to shape up Linux emulation well (It's ironic that WSL1 ironed out their worst quirks just as WSL2 was introduced, although that was without io_uring) or just add an option for Podman to have a minimal pv-Linux kernel via bhyve to get better compatibility.

          • frumplestlatz an hour ago

            Indeed, ideally we could get docker on FreeBSD using the same approach as is used on macOS — automatically run (one or more) Linux VMs under bhyve.

            I wonder if FreeBSD ought to consider a WSL2-style approach to Linux binary compatibility, too.

            Keeping the Linux syscall compatibility layer up-to-date has always been a resource problem, especially when syscalls depend on large, complex Linux kernel subsystems that just don’t map cleanly to FreeBSD kernel facilities.

    • jmmv an hour ago

      > I delayed upgrading to 15.0 after it was released, but last weekend I finally did it, and it left me wondering why I hadn't done it sooner, because it went quickly and smoothly.

      I haven't done that yet because I think I'd want to switch to pkgbase but that makes me nervous. Did you go with that option or continued to use the sets?

      • krylon 7 minutes ago

        I haven't switched to pkgbase. Yet. I don't intend to for the time being. I set up a VM to test it, but I haven't gotten around to actually testing it.

      • sidkshatriya 14 minutes ago

        Why not create a boot environment and try out FreeBSD 15 with pkgbase ? If the experiment is successful just make the boot environment the default otherwise throw it away...

        With such powerful tools I find it fascinating that FreeBSD users are not more willing to experiment !

  • aap_ 5 minutes ago

    I was using FreeBSD (after NetBSD) as my primary system for a while in school (no, i can't watch this youtube video, flash doesn't run on FreeBSD). i still use it for my home server, it's just cozy.

  • MarkusWandel 3 hours ago

    Early in my Unix-ish at home journey (26-ish years ago) I tried FreeBSD. It was so Unix because, well, it is. An operating system, not a collection of parts. I found at the time in Linux land Debian felt similar.

    But there is always pressure for more features, more bloat. In Linux, on the plus side, I can plug in some random gadget and in most cases it just works. And any laptop that's a few years old, you can just install Fedora from its bootable live image, and it will work. Secure boot, suspend, Wifi, the special buttons on the keyboard, and so on. But the downside is enormous bloat and yes, often the kind of tinkering you really don't want to do any more, such as the Brother laser printer drivers still being shipped as 32-bit binaries and the installer silently failing because one particular 32-bit dependency wasn't autoinstalled. Or having to get an Ubuntu-dedicated installer (Displaylink!) to run on Fedora.

    But here you have the "mainstream" Unix-ish OS absorbing all the bleeding edge stuff, all the bloat. Allowing FreeBSD free reign to be pure, with a higher average quality of user, which sets the tone of the whole scene. An echo of the old days, like Usenet before "Eternal September" and before Canter & Siegel - for those old enough to remember how it all felt back then.

    • sidkshatriya 3 hours ago

      > But the downside is enormous bloat

      If you think Linux can have "enormous bloat" then Windows bloat by the same standards is terrifyingly humongous (and slow!).

    • philistine 2 hours ago

      FreeBSD is the macOS to Linux's Windows. Or better yet, the iOS to Linux's Android.

      • steve1977 an hour ago

        I mean, parts of FreeBSD literally are in macOS and iOS...

  • commandersaki 3 hours ago

    Ran a FreeBSD colocated server for about a decade that went through generations of hardware. I really want to like the OS, except it's most touted feature, the network stack, was consistently unreliable for me using Intel NICs on Supermicro servers. They would go offline usually after some load due to mbuf resource exhaustion. I never got to the bottom of it even though I posted to the bugs database and would diligently follow up and perform experiments. This also happened on different incarnations of server hardware, so it wasn't the same physical NIC having the issue, but different varieties.

    Anyways had enough of the random downtime, I just switched to Linux which didn't have these issues.

    I'd say the best part of FreeBSD though is freebsd-update which was a game changer from the previous make world shenanigans.

    • kev009 an hour ago

      Intel has had a somewhat awkward relationship with FreeBSD forever. While they are forced to support it (for $reasons) they never have properly covered it.

      I would say as of FreeBSD 12-13 most major issues are addressed from 1gig up to current 100g. There is an odd bug in 2.5g igc where some users have interface stalls whilst others like Netgate are shipping large numbers without issue, waiting to hear if this is firmware or not.

      Source: I maintain several of the Intel drivers on a volunteer basis and used to send several Tbit/s to the Internet over them professionally.

    • adrian_b 40 minutes ago

      I do not believe that your problems are typical for FreeBSD servers.

      I have been using FreeBSD servers for around 30 years. Most of them had Intel NICs and I have used at least 5 or 6 different kinds of Supermicro motherboards, both with Xeon and with Epyc.

      Most servers have worked 24/7, without being rebooted for years and without having any minute of downtime except when I did some hardware upgrade or kernel upgrade.

      I do not doubt that you had the problems described, but there must be some very unusual circumstances that have caused this. I would not be surprised if there was some problem with the version of Supermicro BIOS of your motherboards, and not with FreeBSD, because I have seen many bugs in Supermicro firmware. Or perhaps you had some buggy version of Intel NICs.

      There is one advantage of Linux over FreeBSD, which is not widely known. Linux has a huge database of known bugs in various peripheral devices, including Ethernet NICs, and when one of those is recognized it applies workarounds for the bugs.

      Like any other operating system, FreeBSD also implements workarounds for peripheral interfaces with known bugs, but because it has a much smaller user base also its database of bugs includes much fewer bugs, typically only those that had been reported by FreeBSD users. Because of this, I have seen cases when some hardware devices did not work well in FreeBSD, while they worked well in Linux, and the reason was always because Linux knew that they must not be used in the standard way, but it applied the corresponding workaround for their bugs.

      Only Windows is shielded from the problems caused by bugs, because the hardware vendors write themselves the Windows device drivers and include in them any required workarounds for their bugs.

      • sidkshatriya 6 minutes ago

        > There is one advantage of Linux over FreeBSD, which is not widely known. Linux has a huge database of known bugs in various peripheral devices, including Ethernet NICs, and when one of those is recognized it applies workarounds for the bugs.

        Almost universal hardware support and workarounds for quirks is precisely the reason why everyone uses Linux even if they might want to use FreeBSD or something else. In other words, this advantage is known and is the reason why Linux is dominant in the server space today.

    • doublerabbit 2 hours ago

      I colocate all my servers that all run FreeBSD.

      Myself has been through generational hardware, and had had zero issues with any apart from when the raid card failed.

      Network has been solid. ZFS has just worked. Not sure what your issues were however colocating since FreeBSD 8, and now colocating 16-CURRENT on my the server. FreeBSD has been rock stable in my books.

      2x Dell R630 and 1x Cisco U220 M5

          doublerabbit@cookie:~ $ uname -a && uptime
          FreeBSD cookie.server 12.2-BETA1 FreeBSD 12.2-BETA1 r365618 GENERIC  amd64
          10:39PM  up 1752 days,  1:31, 1 user, load averages: 0.64, 1.30, 1.31
    • dewarrn1 2 hours ago

      Hail u/cperciva.

  • amadeuspagel 5 hours ago

    > Over the years, FreeBSD has served me well. At a certain point it stepped down as my primary desktop - partly because I switched to Mac, partly because of unsupported hardware - but it never stopped being one of my first choices for servers and any serious workload.

    Not my idea of love. Maybe that hardware was supported on Linux. Switch from Linux to FreeBSD so that you can later switch to Mac when you get frustrated with unsupported hardware is not a good pitch.

    • freeopinion 4 hours ago

      FreeBSD supports a much larger range of hardware than MacOS. It's a bit strange to bemoan hardware support, then switch OS and buy very specific hardware for that OS.

      Imagine quitting MacOS because it doesn't support Realtek RTL8188CUS.

      • pjmlp 4 hours ago

        Something that a Mac user or developer, those that have been on the ecosystem for decades would never bother to do anyway.

      • bitwize 43 minutes ago

        Well it just so happens that the best hardware in the world for desktop use—literally years ahead of any competition—is made by the makers of macOS and is totally supported by macOS.

        • adrian_b 24 minutes ago

          What you say is true only when you define "desktop use" in a certain way, which corresponds to what an Apple PC is good for.

          I define "desktop use" in another way, and for my definition any Apple PC is completely non-competitive, by having a much lower performance and a much higher price than a desktop PC using an AMD Ryzen CPU.

          Apple PCs have exceptional single-thread performance, but that is irrelevant for me. I care about multi-threaded performance and especially about floating-point FP64 and big integer computational throughput, for which the Apple CPUs are weak, one could say years behind their competition, except that Apple does not make any attempt to compete in this domain.

          An Apple PC may be the optimum PC for your needs and that is fine, but you should not believe that any computer user has the same needs as you.

    • nullpoint420 5 hours ago

      100%. It reminds me of how a ton of FreeBSD devs moved to Mac during the Darwin days. Then they were abandoned by Apple once they stopped contributing to upstream.

      • frumplestlatz 4 hours ago

        We weren’t abandoned by Apple — Apple never contributed to upstream. Darwin and OpenDarwin were APSL projects and never fed code back into FreeBSD.

        Using macOS meant we got laptop hardware that worked reliably, including Wi-Fi, running a more or less BSD-derived userspace.

        The lack of graphics and Wi-Fi driver support on the *BSDs is not Apple’s fault. It has always been a resource issue.

        Thanks to the AT&T lawsuit, Linux secured momentum at a critical juncture — and here we are. Path dependence and the complexities of real life mean that “winning” is never just a question of technical merit.

        • pjmlp 4 hours ago

          A consequence of the license, which allows Apple and Sony to do exactly that.

          • frumplestlatz an hour ago

            I and other FreeBSD developers are okay with that — if we weren’t, we’d be using a different license.

            • pjmlp 39 minutes ago

              Looking to some complaints doesn't feel like everyone is.

        • hideout_berlin 3 hours ago

          do you remember opendarwin? i was also at puredarwin but the project seams death

          • frumplestlatz an hour ago

            Yes, and Apple did kill it, unfortunately — but it was never an effort to push code upstream into the BSDs.

  • Hendrikto 8 hours ago

    A week ago, I decided to set up my home server with FreeBSD, after the HDD failed, just to try it out. The setup was quick and easy and everything works fine so far.

    I am just not sure it is worth leaving the Linux ecosystem. What if I want to run a Docker container? Do I have to trust random people for ports of software that runs natively on Linux, or port it myself?

    FreeBSD seems good so far, but community and ecosystem are important.

    • vermaden 6 hours ago

      No one prevents You from installing Linux in a Bhyve VM and running Docker there.

      Overhead of FreeBSD Bhyve Hypervisor is about 0.5% (measured in benchmarks) so You loose nothing.

      Here You have easy and complete jumpstart into Bhyve in FreeBSD:

      - https://vermaden.wordpress.com/2023/08/18/freebsd-bhyve-virt...

      Regards, vermaden

      • ComputerGuru 5 hours ago

        Isn't that no longer necessary? Doesn't linuxulator + podman suffice?

        • sidkshatriya 3 hours ago

          > Doesn't linuxulator + podman suffice?

          No it is not reliable enough. Some syscalls not implemented, there are edge case issues with procfs etc. Best to execute in a Linux VM.

    • 0x457 3 hours ago

      > I am just not sure it is worth leaving the Linux ecosystem. What if I want to run a Docker container? Do I have to trust random people for ports of software that runs natively on Linux, or port it myself?

      You already trust random people in linux, you have to trust even more random and more people when you run docker.

      Ports are quite large collection already. If you port yourself it's either up to 20 minutes plus compilation time or major nightmare. More and more software today assumes you run on linux only.

      I think FreeBSD is great for setup and forget. If you have to interact with it regularly it's not worth it. Definitely not worth it for desktop.

    • Gud an hour ago

      You should avoid Docker, is the obvious answer, and grow to love FreeBSD jails.

    • mghackerlady 4 hours ago

      it isn't anywhere close to the convenience of docker, but if you just need containerised OS-level virtualization FreeBSD has Jails which are really cool

    • cess11 32 minutes ago

      If you just want to run a Docker container casually, perhaps do it on your personal computer instead of the home server. If there is some service you really can't manage to get running with jails or right on the BSD, bhyve and guest Linux should be easy enough.

    • shevy-java 6 hours ago

      I can not answer the other questions; for me Linux worked and works better. But that statement here:

      > Do I have to trust random people for ports of software that runs natively on Linux, or port it myself?

      This is a bit problematic in my opinion because ultimately we have to trust all who write open source code. This works well for the most part but there are malicious actors too. See the xz backdoor as example. Or various state actors who want to sniff after people. Age verification is the current attempt to sniff for people data, trying to push legislation by claiming "this is only to protect children" (while it has some interesting side effects, e. g. becoming a stepping stone for anyone wanting to sniff user data and relay this).

      > FreeBSD seems good so far, but community and ecosystem are important.

      Well, there are many more Linux users. Whether that is better or worse ... but it is a fact too.

  • CodeCompost 4 hours ago

    I'd love to move my home server to FreeBSD but I would like to run Immich on it.

    Immich assumes you're running Docker and I can't seem to get Linux running in a bhyve VM with Intel Quick Sync acceleration.

  • gosukiwi 3 hours ago

    When I tried FreeBSD, I was also blown away by the manual, so simple, such high-quality documentation. I think what I liked the most is that it felt coherent, unlike modern OS like Linux and Windows. I think macOS might be the most cohesive of the popular OS's.

  • seethishat 3 hours ago

    I love OpenBSD for similar reasons, except, I still run it as my primary desktop and on an old Chromebook. It just works. No drama with updates. Upgrade every six months. I'd be lost without it.

    • hideout_berlin 3 hours ago

      i plan to run netbsd on my chromebook do you have a good manual? or how to?

  • stego-tech 3 hours ago

    I think I finally know what to do with my second NUC: FreeBSD.

    I'm in the process of converting and consolidating all my home infra into a mono-compose, for the simple reason I don't want to fiddle with shit, I just want to set-and-forget. The joy of technology was in communications and experiences, not having to dive through abstraction layers to figure out why something was being fiddly. Containers promised to remove the fiddliness (as every virtualization advancement inevitably promises), and now I'm forced to either fiddle with Docker and its root security issues, fiddle with Podman and reconfiguring the OS for lower security so containers don't stop (or worse, converting compose to systemd files to make them services), or fiddle with Kubernetes to make things work with a myriad of ancillary services and CRDs for enterprises, not homelabs.

    For two years now, there's been a pretty consistent campaign of love-letters for the BSDs that keep tugging at what I love about technology: that the whole point was to enable you to spend more time living, rather than wrangling what a computer does and how it does it. The concept of jails where I can just run software again, no abstractions needed, and trust it to not misbehave? Amazing, I want to learn more.

    So yeah, in lieu of setting up the second NUC as a Debian HA node for Docker/QEMU failover, I think I'm going to slap FreeBSD on it and try porting my workloads to it via Jails. Worst case scenario, I learn something new; best case scenario, I finally get what I want and can finally catch up on my books, movies, shows, and music instead of constantly fiddling with why Plex or Jellyfin or my RSS Aggregator stopped functioning, again.

  • w4rh4wk5 2 hours ago

    For someone who has multiple years of experience using Linux for desktop and servers, what's the best way to get into FreeBSD? Any specific recommendations for desktop, like is Wayland ready on FreeBSD?

    • adiabatichottub 6 minutes ago

      I've been using both Linux and BSD since 2000. Honestly, I prefer Linux on the desktop. My dev workstation runs Arch, and I keep a FreeBSD VM running to do OS and ports builds.

      As a server OS I find FreeBSD really consistent and easy to administrate. I never have trouble finding things: packages always go in /usr/local. The old-school init system works great at what it's designed to do, and all the startup scripts are easy to understand. The whole thing just feels kind of cozy and familiar. If you like working in a shell then FreeBSD just kind of feels like /home.

      Coming from modern Linux though, some of the constructs can feel a bit outdated. Usually this gives me a warm fuzzy feeling, but sometimes it's a real pain (looking at you, make(1)). It's like hacking Perl, once you understand the idiom and what it's good at then you can be good friends.

      If you want to run a mail server for 20 years and go through multiple hardware and OS upgrades with minimal pain and maximal uptime then you can't beat it.

    • xenophonf 2 hours ago

      I love FreeBSD for its documentation. To answer your question about Wayland specifically:

      https://docs.freebsd.org/en/books/handbook/wayland/

      If you want something with a graphical environment ready to run, check out GhostBSD, which is based on FreeBSD and features MATE:

      https://www.ghostbsd.org/

  • sgt 3 hours ago

    Well written and clearly not AI generated. So refreshing these days.

  • evanjrowley 4 hours ago

    One of my favorite FreeBSD features is first-class support for ZFS boot environments. These have been working in FreeBSD/Solaris since 2008[0]. Having each boot environment available as a ZFS snapshot capable of being managed the same way as any other dataset, capable of being sent and received, is such a powerful feature. I dilligently watch the immutable/atomic Linux space to see when something implements this in the same fashion.

    Ubuntu could have been the one, but they reversed course after dropping support for Zsys in 2022[1].

    If there are others, then please let me know, but as far as I can tell, the closest approximations in Linux are:

    - Btrfs with Snapper in OpenSuse Tumbleweed/MicroOS

    - Snapshot Manager/Boom in RHEL

    - OStree in Fedora Atomic, CarbonOS, EndlessOS

    - Bootable container implementations in Fedora CoreOS, RHEL10, CarbonOS, Bazzite, BlendOS, etc.

    - Snaps in Ubuntu Core

    - Generations in NixOS and Guix

    - A/B update mechanism in ChromeOS, IncusOS

    - OverlayFS in Nitrux Linux

    - Ad-hoc implementations with Arch, Alpine, etc.

    Excluding the ad-hoc implementations, only OpenSuse and Red Hat approaches allow you to treat your system image and system data the same way. They're great, but fundamentally incompatible, and neither has caught on with other distributions. Capabilities of both approaches are limited compared to ZFS.

    The strangest part of the Linux situation IMHO is, every time ZFS on Linux is discussed, someone will invariably bring up XFS. For the past decade, XFS on Linux contains support for Copy-on-Write (CoW) and snapshots via relinking. If this is the preferred path on Linux (for users who don't want checksumming of ZFS/Btrfs/Bcachefs), then how come no major distros besides Red Hat have embraced it[2] to provide an update rollback functionality?

    I concede that most of the other approaches do provide a higher level level of determinism for what your root system looks like after an upgrade. It's powerful when you can test that system as an OCI container (or as a VM with Nix/Guix). FWIW, FreeBSD can approximate this with the ability to use it's boot environments as a jail[3].

    [0] https://daemonforums.org/showthread.php?t=7099

    [1] https://bugs.launchpad.net/ubuntu/+source/ubiquity/+bug/1968...

    [2] https://docs.redhat.com/en/documentation/red_hat_enterprise_...

    [3] https://man.freebsd.org/cgi/man.cgi?query=bectl&sektion=8&ma...

  • myylogic 16 minutes ago

    beacuse u are lucky

  • smm11 4 hours ago

    I could never get sleep to work, and got tired of rebooting 17 times a day.

    • ogogmad 3 hours ago

      OpenBSD might have "better" support for sleep and hibernate, but I didn't succeed in installing it on this laptop: I think it required me to connect an Ethernet cable, which I wasn't going to do.

      Veering even more off-topic: I've just installed OpenSUSE Kalpa on this laptop. That's not regular OpenSUSE, by the way. Previously, each of the like, 5 problems I've encountered doing it, would've caused me to give up - but ChatGPT helped me fix all of them! I think this is going to become my daily driver for a while now.

  • imagetic 5 hours ago

    me too

  • SanjayMehta 5 hours ago

    I used to but driver support for wireless devices was so inconsistent I had to move to Linux.

    • crdrost 5 hours ago

      That's unintentionally hilarious -- some of us remember 15-20 years ago when flaky support for wireless devices was the biggest reason people would decide Linux wasn't ready for desktop yet and avoid switching from Windows to Linux. (Well, Windows to dual-boot -- Windows users were never fully willing to let go of the video games angle at the time.)

      • Gud 39 minutes ago

        Linux had better WiFi 20 years ago than FreeBSD has today.

        I still prefer FreeBSD.

  • shevy-java 6 hours ago

    > had trained me to hunt for documentation in fragments: often incomplete, often outdated, sometimes already stale after barely a year.

    This is indeed a problem now that google search is next to useless. And AI further degrading the quality.

    I work around it to some extent by keeping my local knowledge base up to date, as much as that is possible; and using a ton of scripts that help me do things. That works. I am also efficient. But some projects are simply underdocumented. A random example is, in the ruby ecosystem, rack. Have a look here:

    https://github.com/rack/rack

    Now find the documentation ... try it.

    You may find it:

    https://rack.github.io/rack/

    Linked from the github page.

    Well, have a look at it.

    Remain patient.

    Now as you have looked at it ... tell me if someone is troll-roflcopter-joking you.

    https://rack.github.io/rack/main/index.html

    Yes, you can jump to the individual documentation of the classes, but does that really explain anything? It next to tells you nothing at all about anything about rack.

    If you are new to ruby, would you waste any time with such a project? Yes, rack is useful; yes, many people don't use it directly but may use sinatra, rails and so forth, I get it. But this is not the point. The point is whether the documentation is good or bad. And that is not the only example. See ruby-webassembly. Ruby-opal. Numerous more projects (I won't even mention the abandoned gems, but this is of course a problem every language faces, some code will become outdated as maintainers disappear.)

    So this is really nothing unique to Linux. I bet on BSD you will also find ... a lack of documentation. Probably even more as so few blog about BSD. OpenBSD claims it has great documentation. Well, if I look at what they have, and look at Arch or Gentoo wiki, then sorry but the BSDs don't understand the problem domain.

    It really is a general problem. Documentation is simply too crap in general, with a few exceptions.

    > if the team behind this OS puts this much care into its documentation, imagine how solid the system itself must be.

    Meh. FreeBSD documentation can barely called the stand-out role model here either. Not sure what the BSD folks think about that.

    > I realized almost immediately that GNU/Linux and FreeBSD were so similar they were completely different.

    Not really.

    There are some differences but I found they are very similar in their respective niche.

    Unfortunately my finding convinced me that Linux is the better choice for my use cases. This ranges from e. g. LFS/BLFS to 500 out of top 500 supercomputers running Linux. Sure, I am not in that use case of having a supercomputer, but the point is about quality. Linux is like chaotic quality. Messy. But it works. New Jersey model versus [insert any high quality here]. https://www.jwz.org/doc/worse-is-better.html

    > Not only that: Linux would overheat and produce unpredictable results - errors, sudden shutdowns, fans screaming even after compilation finished.

    Well, hardware plays a big factor, I get it. I have issues with some nvidia cards, but other cards worked fine on the same computer. But this apocalypse scenario he writes about ... that's rubbish nonsense. Linux works. For the most part - depending on the hardware. But mostly it really works.

    > I could read my email in mutt while compiling, something that was practically impossible on Linux

    Ok sorry, I stopped reading there. My current computer was fairly cheap; I deliberately put in 64GB RAM (before the insane AI-driven cost increases) and that computer works super-fast. I compile almost everything from source. I have no real issue with anything being too slow; admittedly a few things take quite a bit of compile-power, e. g. LLVM, or qt - compiling that from source takes a while, yes, even on a fast computer. But nah, the attempt to claim how FreeBSD is so much faster than Linux is, that's simply not factual. It is rubbish nonsense. Note that OpenBSD and NetBSD folks never write such strangeness. What's wrong with the FreeBSD guys?

    • draga79 4 hours ago

      Just one small note: those experiences are from 2002 and I was writing about my first experience when running it on my Sony Vaio. Running on a modern 64Gb Ram hardware is a totally different experience, 24 years later

    • guenthert 4 hours ago

      >> I could read my email in mutt while compiling, something that was practically impossible on Linux

      > Ok sorry, I stopped reading there.

      Why? That's a treasured feature. https://xkcd.com/303/

    • anthk 5 hours ago

      The Arch Wiki it's a joke as it gets obsolete with every major upgrade. OpenBSD has the FAQ and all of the base it's throughly documented. GNU/Linux manpages? Info pages? Often either incomplete or missing. Don't let me start on compatibility. On your beloved overengineerd turd, you need to resort to either containers or hacks to run 10 yo software. FreeBSD will just run it through compatNx libraries, where N is the version number, and there's a -32 (bit) suffix for obvious needs. Now, how can you run legacy software under current Arch Linux? Yeah, there's Flatpak, but I've found broken software on it.

      Altough on compatibility, under 9front everything it's statically compiled, period. Compile, store, copy back, run.

      Docs? man pages, and /sys/doc. Easier to be understood and set.

      Current Unixes are too bloated. Yes, FreeBSD too. NetBSD and OpenBSD, a bit less. GNU/Linux it's such a monster that over time I'd guess Guix will just keep Coreutils as a toolbox and everything will be jitted Guile/Scheme, and for the rest of the distros, it will just be Wayland+Gnome+Flatpak OS. Now try hacking that. Try creating a working 32 bit OS with it. Documentation beyond GUIX' info files? Good luck, man will be a legacy tool called from Info from Guix.

      SystemD? Over time, Gnome won't be under non SystemD OSes. Forget it under BSD's and shims, KDE will be the only option (and under Guix too). The irony, GNU Networked Object Model Environment outside of the GNU os.

      Meanwhile, by default GNU/Linux has more propietary bits in the kernel than GNU bits. Untar it, Radeon depends on nonfree firmware. So does tons of SOCS, audio devices, wireless cards. Linux Libre + Guix? Not with Gnome, maybe with a Guile JIT/AOT'ed desktop environment, a la Cosmic but with AOT'ted Guile instead of Rust. Forget cohesiveness, your Redhatware OS will be as native to the rest as Waydroid inside Fedora Silverblue. Seamless, but not native. And with similar issues on running some software in Waydroid without hacks faking up the existence of some blobs.

      And as tons of infra depends on SystemD and blobs, guess what will happen to Arch and the rest of the distros. It will jut be second class, Pacman packaged Fedoras.

    • 4fterd4rk 5 hours ago

      AKSHUALLY...