The Linux Ship of Theseus

  1. pick any distro and install it.

  2. Then, without installing another distro over the top of it, slowly convert it into another distro by replacing package managers, installed packages, and configurations.

System must be usable and fully native to the new distro (all old packages replaced with new ones).

No flatpaks, avoid snaps where physically possible, native packages only.

EDIT: Some clarification on some of the clever tools brought up here:

chroot, dd, debootstrap, and partition editors that allow you to install the new system in an empty container or blanket-overwrite the old system go against the spirit of this challenge.

These are very useful and valid tools under a normal context and I strongly recommend learning them.

You can use them if you prefer, but The ship of Theseus was replaced one board at a time. We are trying to avoid dropping a new ship in the harbor and tugging the old one out.

It may however be a good idea to use them to test out the target system in a safe environment as you perform the migration back in the real root, so you have a reference to go by.


Easy: pick two similar distros, such as Ubuntu and Debian or Manjaro and Arch and go from the base to the derivative.

Medium: Same as easy but go from the derivative to the base.

Hard: Pick two disparate distros like Debian and Artix and go from one to the other.

Nightmare: Make a self-compiled distro your target.

  • @[email protected]
    link
    fedilink
    42 days ago

    Shouldn’t everyone that installed Arch the right way be able to do it on most distros, simply after installing Pacman?

    Though I think changing (shrink, create new, migrate, delete old) the partition layout would count as installing another distro on top…

    Want a challange? Start with something like Silverblue.

    • swab148
      link
      fedilink
      62 days ago

      Arch already has apt in the repo, so I’d imagine it’s not super hard to build your own Debian from there.

  • Jiří Král
    link
    fedilink
    -4
    edit-2
    2 days ago

    I am not educated enough about this, but don’t these kind of games unnecesarrily strain all the servers that host the packages for people that really need them for download and most of these people run these servers for free in good will and faith that they will serve meaningful needs with positive impact? I am sorry for spoiling the fun, but I felt like I had to point this out.

    • SemperverusOP
      link
      fedilink
      English
      8
      edit-2
      2 days ago

      As other commenters have said, its about as strenuous as doing two normal installs.

      However, if you want to do this challenge but feel guilty about the consumed resources, consider donating to the two distros you are performing this with to cover any additional service costs. In all likelihood it’ll only cost them fractions of pennies, but any reason to donate to FOSS is always appreciated.

    • @[email protected]
      link
      fedilink
      162 days ago

      How is this any less meaningful than any other use case? Is downloading a distro to play video games ok? To shitpost on social media? To watch clickbait videos on youtube? Why is this in particular a bad use of resources?

    • @[email protected]
      link
      fedilink
      102 days ago

      No? It’s the same amount of “strain” as doing two full OS installs of the different distros.

      • Jiří Král
        link
        fedilink
        2
        edit-2
        2 days ago

        You are kind of right. I should have thought about that before commenting.

    • @[email protected]
      link
      fedilink
      112 days ago

      Reminds me of MattKC, a guy on YouTube who does similar stuff. He ported the .Net framework to win95. very interesting videos, if think this challenge would be exactly his type.

    • antsu
      link
      fedilink
      502 days ago

      But the rules say the system must be usable.

    • slazer2au
      link
      fedilink
      English
      118 hours ago

      Why does that sound familiar.

      Did they load an OS into ram to run ssh then rebuild the machine, also some VPS that the provider was dragging their feet on remote hands.

      • @[email protected]
        link
        fedilink
        217 hours ago

        I can’t find it now but basically something like that yeah. VPS provider only gave them SSH on linux so couldn’t run the openbsd installer any normal way either

  • Jonathan
    link
    fedilink
    222 days ago

    “Medium: Same as easy but go from the derivative to the base.”

    I can’t quite recall, but I think I did exactly that with Ubuntu -> Debian once upon a time. I think Ubuntu was only a year or so old though, so there wasn’t a huge amount of divergence back then. As a bonus anecdote I also attempted a semi-successful build of Gentoo on a PPC Mac around the same time (nothing before or after that has compared in its level of nightmare).

    • @[email protected]
      link
      fedilink
      English
      62 days ago

      I also attempted a semi-successful build of Gentoo on a PPC Mac around the same time (nothing before or after that has compared in its level of nightmare).

      Amen!

  • Go-On-A-Steam-Train
    link
    fedilink
    172 days ago

    I “broke” linux mint just by trying to pop KDE on, had to timeshift because it messed up my keyboard layout and a whole bunch of other things with my display.

    I don’t know how people do these crazy changes without pain, and have a feeling the answer is simply “there’s pain” 😂

    • @[email protected]
      link
      fedilink
      2
      edit-2
      15 hours ago

      theres pain but its also very satisfying to pull this kind of stuff off. im more of a stable system kind of guy these days.

    • @[email protected]
      link
      fedilink
      English
      42 days ago

      Reminds me of trying NsCDE… it changed a ton of settings and no other desktop looked right after that. I ended just blowing away my home folder and restoring my files

  • @[email protected]
    link
    fedilink
    142 days ago

    I have seen dozens of systems migrated from Gentoo to CentOS by live swapping the userspace and eventually rebooting into the new kernel. A hair raising experience to be sure.

  • @[email protected]
    link
    fedilink
    122 days ago

    I once switched from Debian i386 to amd64 in-place. That was MUCH harder than you would expect, I guess somewhere between medium and hard in your list. That server is still running that install btw, so in the end it all worked out.

    • @[email protected]
      link
      fedilink
      1
      edit-2
      15 hours ago

      i did a bit of back and forth with a couple of debian based distros in the past but it always ended up buggy and weird. it was a desktop install though, i imagine servers would be simpler.

    • Jonathan
      link
      fedilink
      32 days ago

      I had forgotten about doing that myself. I did that on a couple servers once the distros had full 64 bit builds. Does that technically count as an architecture swap in-place as well?

  • @[email protected]
    link
    fedilink
    English
    9
    edit-2
    2 days ago

    So, any distro to any other distro?

    • Installs Fedora Silverblue
    • Rebases to Bazzite

    Jobs done chief!

      • SemperverusOP
        link
        fedilink
        English
        82 days ago

        The beauty of this exercise is you can make it as easy or challenging as you want just by changing the targets, and finding different combinations can keep things interesting.

    • Norah (pup/it/she)
      link
      fedilink
      English
      13 hours ago

      Bazzite on GNOME? Rebasing from GNOME to KDE causes so many headaches. Ask me how I know (yes I’m aware they tell you not too).

  • @[email protected]
    link
    fedilink
    English
    72 days ago

    Love the idea of the challenge, my issue would be lack of a validator tool to confirm I’d completed the challenge - any suggestions?

    • SemperverusOP
      link
      fedilink
      English
      3
      edit-2
      1 day ago

      After completing the challenge and making sure your system is usable and can survive a reboot:

      If you’ve kept the old package manager, search for installed packages and make sure that the package manager itself is the only thing left. Then delete it.

    • @[email protected]
      link
      fedilink
      71 day ago

      You use the new franken system to do an update to the new version of that distro’s flavour without bricking the system.