Want to read Slashdot from your mobile device? Point it at m.slashdot.org and keep reading!


Forgot your password?
Upgrades Operating Systems Software BSD Linux

Depenguinator "Upgrades" Linux to BSD 616

cperciva writes "Many systems around the world have been possessed by penguins and dead rats. It would be nice to exorcize these evil spirits, but this can be difficult without physical access to the machines in question. Thanks to a new depenguinator, it is now possible to upgrade Linux systems to run FreeBSD 5.x without requiring anything more than an SSH connection." Clever idea.
This discussion has been archived. No new comments can be posted.

Depenguinator "Upgrades" Linux to BSD

Comments Filter:
  • by vinsci ( 537958 ) on Tuesday December 30, 2003 @09:29AM (#7834294) Journal
    Personally, I find this howto more useful. ;-) HOWTO - Install Debian Onto a Remote Linux System [sourceforge.net]
  • by CaptainBaz ( 621098 ) on Tuesday December 30, 2003 @09:35AM (#7834323) Homepage Journal
    you need debootstrap. now is not the best time to be looking for the rpm, as people.debian.org is still down after the brk() attack, but the relevant section of the install docs is here [debian.org].
  • by vadim_t ( 324782 ) on Tuesday December 30, 2003 @09:35AM (#7834330) Homepage
    Use debootstrap. It will create a minimal install in any folder. Then chroot, and there you go, a small Debian system. Using that, you can either install Debian on another partition while running another distribution, or I suppose you also could replace your current install with Debian by booting into single user mode, and replacing your old system with Debian.

    While you should be able to simply chroot into your new system and start adding stuff, I'd be a very good idea to boot it first. Debian will need to run some scripts on boot to finish configuring itself.

    I'd go with the first option. The second one is too easy to screw up if you don't know what you're doing.
  • by Killeri ( 238792 ) * on Tuesday December 30, 2003 @09:36AM (#7834337) Homepage
    I would guess the easiest way to do this is to get a Knoppix CD image, unpack it to disk and then boot from it, just like the source article describes.
  • by Marsala ( 4168 ) on Tuesday December 30, 2003 @09:54AM (#7834457) Homepage

    Well, I don't know of a tool, but how about HOWTO [sourceforge.net]?

    Have a good one. :)

  • by cperciva ( 102828 ) on Tuesday December 30, 2003 @10:04AM (#7834514) Homepage
    So all this does is write to the boot partition and load a barebones copy of bsd on a ramdisk?

    It also inserts a system configuration file into the filesystem image; and the filesystem in question -- UFS2 -- is one for which Linux support is rather lacking, so the filesystem image has to be built entirely within userland (thanks NetBSD!).
  • Re:Useful! (Score:3, Informative)

    by cperciva ( 102828 ) on Tuesday December 30, 2003 @10:17AM (#7834590) Homepage
    This is PERFECT for one of those Dedicated Server hosting providers that don't let you touch your box at all.

    That was the initial motivation; although it turns out that this is also very useful for installing FreeBSD on easily accessible servers, since loading the entire OS into a memory disk makes it possible to do things which sysinstall doesn't support -- for example, creating a vinum root system.
  • "having to do a make world on 300 boxen"

    Not any more, and 'make world' is being deprecated in favor of 'make buildworld'. The difference is, that 'make buildworld' is totally self contained. You do 'make buldworld' on one machine, export /usr/obj (and /usr/src as well?) as nfs, mount it on your 300 boxen, and you only need to install the shiny new bsd with 'make installworld'. That's it. So it is actually quite easy to deploy on a large server farm. You would go the same way with the ports btw: build on one machine and have it make pakcages, than install the packages with pkg_add -r whatever on the rest of the machines. Neat. :)
  • by Alioth ( 221270 ) <no@spam> on Tuesday December 30, 2003 @10:55AM (#7834837) Journal
    I use User-Mode-Linux for my web/email/DNS servers. The co-lo that rents servers only rents RedHat servers. The 'host' still runs RedHat, but really very little of it - I have my own custom kernel (with skas patch, very useful if you are running UML virtual machines) on the RedHat host, plus iptables to act as a firewall. The RedHat host conceptually just runs as a network router.

    The real servers are all UML instances, all running Debian. The UML page on Sourceforge has a minimal Debian root disk image. I based my root images from these (created a new filesystem on the RedHat system of the appropriate size, mounted both, and cp -a from the minimal Debian install to the root filesystem file I was going to use, edited /mnt/etc/network/interface etc. to set the right IP addresses etc.) then booted. After that, it's just a case of using apt-get to get the packages you want to run.

    The nice thing about separating all your services on different VMs within one host is you can apply decent firewall rules for each VM. If, say, your DNS UML got rooted because of an unpatched BIND (unlikely with Debian, since you can just apt-get update && apt-get upgrade to keep up to date) the skript kiddie - instead of having the run of your whole server and being able to deface your website (or worse) is locked into your DNS UML. Add proper egress firewall rules with iptables on the host, and you can prevent most skript kiddie attacks from being able to work.

    Although I like the BSDs (I like all UNIX style OS, well, except a certain company whose name need not be mentioned), they can't yet (natively) do the equivalent of user mode Linux which is something I find incredibly useful. Hopefully they will in the future.
  • by R.Caley ( 126968 ) on Tuesday December 30, 2003 @11:06AM (#7834957)
    [having to do a make world on 300 boxen is not my idea of time well spent.]

    mount /usr/src
    mount /usr/obj
    cd /usr/src
    make installkernel installworld
    scp -r build:/etc/\* /etc

    This is assuming all your machines are identical. If not you'd have to be more careful about the config stuff, and use mergemaster, but that would be the case for any OS.

    Of course, NFS is not something you'd want to use to a remote machine, the idea of opening RPC ports in my firewall makes my skin crawl. But for upgrading multiple machines on your own network, the BSD system is really quick and clean.

    If something could be done to improve mergemaster, the ease of upgrading FBSD would be the killer argument for the death of the penguin. I've never seen a description of how to upgrade linux which didn't make me decide it would be easier just to do a clean install ofa new version. If there is such a description/method, please post and earn some well deserved karma.

  • by swb ( 14022 ) on Tuesday December 30, 2003 @11:19AM (#7835061)
    In the FreeBSD Ports collection, there are many Ports marked as broken, and many more unmaintained and suffering from bit-rot.

    Name any five that depend on each other and are important for real-world use? Ports suffers from both the desire to be large and from the fact that they're generally supported by one person. I've been running FreeBSD now for nearly 5 years and have only run into a broken port once, snmpd, which broke after a significant change in system variables, which in turn broke snmpd. It was fixed quickly, and since then every time I've built a port it's built.

    How exactly is FreeBSD 5 a "dramatic step-up from ANY Linux distro"? FreeBSD releases are only supported for 12 months. Then you have to upgrade. In comparison, Debian supports its releases for at least two years, and RHEL offers a whopping FIVE years. That's right, five. This matters in real-world use.

    You don't understand FreeBSD releases. There are point releases (eg, 5.2), -STABLE branches and -CURRENT branches. Most people track a -STABLE branch. Tracking a stable branch provides you with bug fixes and occasionally some new features backported from -CURRENT. Tracking -STABLE requires you to periodically rebuild the system from source, but this is FreeBSD's *advantage* -- it's a single, coherent system that can be easily and totally recompiled from up-to-date source code.

    I've been running 4-STABLE now for almost 4 years and its still a supported (ie, active development and maintenance) branch of FreeBSD. The 2.2 and 3 STABLE branches are still there and I think 3 was still supported until the 5-STABLE branch was created.

    Maintaining FreeBSD is easy if you track -STABLE and supported for years, and its often possible (albeit not necessarily recommnede) to upgrade from one major release to another -- I did it from 3.x to 4.x. In this manner (and not just point RELEASEs), FreeBSD revisions are suppported for years -- far longer than even most sane people would run a given revision of software.

    I never did more chasing than I did trying to keep Dead Rat systems updated; either I used RPMs and prayed that the package author didn't decide to switch a bunch of compilation options, or a built packages from source, which meant I had to do my own porting. And then there was libc upgrades and all other manner of horror of trying to maintain an OS that was a kernel with a bunch of other stuff glued on without any coherency.

    I'll grant some Linux distros have better turnkey desktop setups, and certainly greater corporate involvement (although ask yourself when "greater corporate involvement" and "better software" were part of the same sentence), and higher visibility.

    But longer suppport, easier maintenance and reliability over the long haul? No way.
  • by jrexilius ( 520067 ) on Tuesday December 30, 2003 @12:30PM (#7835642) Homepage
    it is a bit of a troll post as the item that would crash under a /. effect is Apache (assuming thats what you are running) not the OS. There is not enough of a performance difference in OS level operations between linux and bsd that would have an impact on your network and webserving daemon's ability to handle a /. Assuming apache 1.3.x, even recompiled to handle more than 256 children you are hard limited by memory and bandwidth. So when you get too many concurrent TCP connections, they just get dropped, regardless of OS.
  • Linux as a server (Score:5, Informative)

    by shani ( 1674 ) <shane@time-travellers.org> on Tuesday December 30, 2003 @12:41PM (#7835739) Homepage
    Interestingly, the k root name server has been running Debian Linux for a year or two now and has not had any "creak". It gets about 1500 queries/second per machine (the root server is distributed geographically via anycasting, and at each site by load balancing), and receives all manner of ill-formed packets.

    Other root servers seem to run Linux (use nmap if you're curious), but I don't know the people running them so I can't be sure.

    Now admittedly this is a very specific type of service: it's a single application that all fits into memory.

    We're going to be moving www.ripe.net and whois.ripe.net from Solaris to Linux in 2004. The WWW server gets about 20 hits/second as you can see here [ripe.net], and the whois server gets around 28 hits/second as you can see here [ripe.net]. These have more complex usage, with disk I/O, new process creation, and so on. I wouldn't let these services migrate if I thought they would be unstable.
  • Re:Thanks, thanks! (Score:3, Informative)

    by cperciva ( 102828 ) on Tuesday December 30, 2003 @12:45PM (#7835781) Homepage
    I've put a static snapshot of mrtg.daemonology.net up here: http://www.daemonology.net/depenguinator/slashdott ing/ [daemonology.net]

    I'll update it from time to time over the next day.
  • by Anonymous Coward on Tuesday December 30, 2003 @01:39PM (#7836414)
    It's somewhat amusing to see a Linux user talking about platform stability. Multiple incompatible package formats, constant libc and GCC ABI breakage, "stable" kernel releases that provide less hardware support because their kernel interfaces are constantly changing, major vendors shipping releases with broken compilers, and so on.

    Then you get Linus telling people that binary kernel modules are supposed to be under the GPL. It's somewhat amazing and sad that Linux obtained so much publicity and commercial attention when it's such a bad platform in terms of stability, and its users are such rabid fanatics.
  • by Oopsz ( 127422 ) on Tuesday December 30, 2003 @02:05PM (#7836752) Homepage
    Tuxissa? [symantec.com]
  • by jusdisgi ( 617863 ) on Tuesday December 30, 2003 @09:43PM (#7841558)
    While I certainly get your main point (rooting one box will leave the rest safe) I simply *must* take issue with your example.

    You say if this guy roots your DNS VM, he won't be able to deface your website. I'll point out the obvious: he now has control over the web address, and can point your website at his own box, where the defaced site lies. Or he can point it at the DNS box itself, install apache, and deface it there.

    Point is, if he roots your DNS server, you are all kinds of jacked.

Friction is a drag.