Skip to main content

Replicating Fedora Machines using Kickstart

Sometimes one wants to install more machines the same as one that is already working.  Replication is one point where Linux is light years ahead of the competition.

Using Kickstart, you can roll out thousands of identically configured machines (with hardware that may be completely different) in a jiffy - Kickstart will automatically install the correct device drivers.

The Skinny

I usually do it manually, since it is too simple to bother scripting:
  • Save file /root/anaconda-ks.cfg
  • Save /etc/yum.repos.d with tar -zcvf yum.repos.d.tgz /etc/yum.repos.d
  • Save the packages list with yum list installed > packages
Use the saved kickstart file to install the new machine, untar the repos and run yum -y install $(cat packages) or yum -y install < packages

Booting Kickstart

Kickstart is the remote control system of the Red Hat Anaconda installer.

A Kickstart installation requires access to the Linux installation media on a local CD-ROM drive or hard drive, or over the network using HTTP or NFS.

If you need just one or two new machines, then do it manually.  If you need hundreds or thousands, then it is worth modifying the Kickstart file to make installation completely hands free.

To use a Kickstart file to install a system:
  1. Boot the system from a Live CD or USB schtick. If you need to modify the boot command, press Esc to access the command line.
  2. If you have not customized the boot medium to use Kickstart, use the ks option to specify the location of the Kickstart file.

    For example, the following boot command specifies that the Kickstart file is on the boot CD:
    boot: linux ks=cdrom:/ks.cfg
    If the Kickstart file is located on an NFS server, you might use a boot command such as the following:
    boot: linux ksdevice=em1 ip=dhcp ks=nfs:192.168.1.100:/ksfiles/ks.cfg
    where ksdevice=em1 specifies the network interface and ip=dhcp specifies that DHCP should be used to configure this interface.
That is all there is to Kickstart - it works.

Synchronizing Two Machines

If you have two existing machines and you want to ensure that they have the same packages installed, then you can use dnf or yum:

Get the list of installed packages on one machine (sort, just makes it nice):
$ rpm -qa --qf "%{name}.%{arch}\n" | sort > packages.lst
Install missing packages from the list on the other machine:
$ sudo dnf install $(cat packages.lst)

Do it both ways and they will end up the exact same.


La Voila!

    Comments

    1. Hi Herman,
      I'm here cuz you mentioned that kickstart was a way to save a particular build of linux to install easily later on. I'm stuck at the "Boot the system from a USB schtick". I've got a live USB and when I get to the boot screen I have the options: Start Fedora, Test this media and Start Fedora, Troubleshooting >. If I press e to edit an option it seems the boot: command is not recognized. I'm sure I'm missing something simple here. Any thoughts?

      ReplyDelete
    2. That is the most difficult part. It could require a bit of faffing around till you figure out exactly when to press the esc key unfortunately!

      https://docs.fedoraproject.org/en-US/Fedora/20/html/Installation_Guide/ap-admin-options.html

      https://docs.fedoraproject.org/en-US/Fedora/20/html/Installation_Guide/s1-kickstart2-startinginstall.html

      ReplyDelete

    Post a Comment

    On topic comments are welcome. Junk will be deleted.

    Popular posts from this blog

    Parasitic Quadrifilar Helical Antenna

    This article was reprinted in OSCAR News, March 2018:  http://www.amsat-uk.org If you want to receive Satellite Weather Pictures , then you need a decent antenna, otherwise you will receive more noise than picture. For polar orbit satellites, one needs an antenna with a mushroom shaped radiation pattern .  It needs to have strong gain towards the horizon where the satellites are distant, less gain upwards where they are close and as little as possible downwards, which would be wasted and a source of noise.  Most satellites are spin stabilized and therefore the antenna also needs circular polarization, otherwise the received signal will flutter as the antennas rotate through nulls. The helical antenna, first proposed by Kraus in 1948, is the natural solution to circular polarized satellite communications.  It is a simple twisted wire - there seems to be nothing to it.  Various papers have been published on helix antennas, so the operation is pretty well ...

    Unlock CRA PDF Forms

    Unlock Canada Revenue Agency PDF Forms It appears that there is a relatively new PDF feature to prevent casual copying and saving of a file and that some programs save PDF files with these foolish features active by default.  Many forms from the Canada Revenue Agency are locked in this way, which makes it difficult to do one's taxes, since one can fill the form, but cannot save it.  One can only print the form.  It should be possible to print to a file or export it to a new PDF file, but it is far better to reset the annoying anti-taxpayer flags, since the 'printed' form cannot be edited easily any more and I always manage to make a mistake or three that need to be corrected after review. If there is a Linux (virtual) machine handy, install qpdf and use it to reset the silly flags: $ su - password # dnf update # dnf install qpdf # exit $ qpdf --decrypt lockedfile.pdf unlockedfile.pdf One doesn't need a password to unlock these flags, so the fix is instant. La voila! He...

    To C or not to C, That is the Question

    As most would know, the Kernighan and Ritchie C Programming Language is an improved version of B, which is a simplified version of BCPL, which is derived from ALGOL, which is the Ur computer language that started the whole madness, when Adam needed an operating system for his Abacus, to count Eve's apples in the garden of Eden in Iraq.  The result is that C is my favourite, most hated computer language , which I use for everything. At university, I learned FORTRAN with punch cards on a Sperry-Univac, in order to run SPICE, to simulate an operational amplifier.  Computers rapidly lost their glamour after that era! Nobody taught me C.  I bought the book and figured it out myself. Over time, I wrote a couple of assemblers, a linker-locator, various low level debuggers and schedulers and I even fixed a bug in a C compiler - not because I wanted to, but because I had to, to get the job done!   Much of my software work was down in the weeds with DSP and radio modems...