container/container-minimal-20.ks | 126 ++++++++++++++++++++++++++++++++++++++ container/fedora-20-container.ks | 12 ++- 2 files changed, 133 insertions(+), 5 deletions(-) New commits: commit f4c8d1b5bbcf889783593b7c85f44ed397690791 Author: Matthew Miller <mattdm@xxxxxxxxxx> Date: Fri Sep 13 13:54:51 2013 -0400 rename this diff --git a/container/container-minimal-20.ks b/container/container-minimal-20.ks new file mode 100644 index 0000000..0422064 --- /dev/null +++ b/container/container-minimal-20.ks @@ -0,0 +1,126 @@ +# This is a kickstart for making a non-bootable container environment. +# +# Convert the result to a tarfile with +# +# virt-tar-out -a fedora.qcow2 / - | bzip2 --best > fedora.tar.bz2 +# +# +# This kickstart file is designed to be used with appliance-creator and +# may need slight modification for use with actual anaconda or other tools. +# We intend to target anaconda-in-a-vm style image building for F20, but +# not necessarily for containers -- that's yet to be worked out. + +lang en_US.UTF-8 +keyboard us +timezone --utc Etc/UTC + +auth --useshadow --enablemd5 +selinux --enforcing +rootpw --lock --iscrypted locked + +zerombr +clearpart --all +part / --size 1024 --fstype ext4 + +# Repositories +repo --name=fedora --mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=fedora-20&arch=$basearch +repo --name=fedora-updates --mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=updates-released-f20&arch=$basearch + +reboot + +# Package list. +%packages --excludedocs + +bash +coreutils +filesystem +setup +yum + +# removed below +findutils +passwd +# https://bugzilla.redhat.com/show_bug.cgi?id=1004976 +firewalld + +%end + + + +%post --erroronfail + +# setup systemd to boot to the right runlevel +echo -n "Setting default runlevel to multiuser text mode" +rm -f /etc/systemd/system/default.target +ln -s /lib/systemd/system/multi-user.target /etc/systemd/system/default.target +echo . + +echo -n "Network fixes" +# initscripts don't like this file to be missing. +cat > /etc/sysconfig/network << EOF +NETWORKING=yes +NOZEROCONF=yes +EOF + +# For cloud images, 'eth0' _is_ the predictable device name, since +# we don't want to be tied to specific virtual (!) hardware +rm -f /etc/udev/rules.d/70* +ln -s /dev/null /etc/udev/rules.d/80-net-name-slot.rules + +# simple eth0 config, again not hard-coded to the build hardware +cat > /etc/sysconfig/network-scripts/ifcfg-eth0 << EOF +DEVICE="eth0" +BOOTPROTO="dhcp" +ONBOOT="yes" +TYPE="Ethernet" +EOF + +# generic localhost names +cat > /etc/hosts << EOF +127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4 +::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 + +EOF +echo . + + +# Because memory is scarce resource in most cloud/virt environments, +# and because this impedes forensics, we are differing from the Fedora +# default of having /tmp on tmpfs. +echo "Disabling tmpfs for /tmp." +systemctl mask tmp.mount + +echo "Removing random-seed so it's not the same in every image." +rm -f /var/lib/random-seed + + +echo "Compressing cracklib." +gzip -9 /usr/share/cracklib/pw_dict.pwd + +echo "Minimizing locale-archive." +localedef --list-archive | grep -v en_US | xargs localedef --delete-from-archive +mv /usr/lib/locale/locale-archive /usr/lib/locale/locale-archive.tmpl +/usr/sbin/build-locale-archive + +echo "Removing extra packages." +yum -C -y remove passwd --setopt="clean_requirements_on_remove=1" +yum -C -y remove findutils --setopt="clean_requirements_on_remove=1" +yum -C -y remove firewalld --setopt="clean_requirements_on_remove=1" + + +echo "Cleaning old yum repodata." +yum clean all +truncate -c -s 0 /var/log/yum.log + +echo "Fixing SELinux contexts." +/usr/sbin/fixfiles -R -a restore + + +echo "Zeroing out empty space." +# This forces the filesystem to reclaim space from deleted files +dd bs=1M if=/dev/zero of=/var/tmp/zeros || : +rm -f /var/tmp/zeros +echo "(Don't worry -- that out-of-space error was expected.)" + +%end + commit 8727de5bf045f4717665fc97e74788af505e322f Author: Matthew Miller <mattdm@xxxxxxxxxx> Date: Fri Sep 13 13:29:06 2013 -0400 add and then remove firewalld (bz #1004976) diff --git a/container/fedora-20-container.ks b/container/fedora-20-container.ks index a2d9e8d..0422064 100644 --- a/container/fedora-20-container.ks +++ b/container/fedora-20-container.ks @@ -40,6 +40,8 @@ yum # removed below findutils passwd +# https://bugzilla.redhat.com/show_bug.cgi?id=1004976 +firewalld %end @@ -103,6 +105,7 @@ mv /usr/lib/locale/locale-archive /usr/lib/locale/locale-archive.tmpl echo "Removing extra packages." yum -C -y remove passwd --setopt="clean_requirements_on_remove=1" yum -C -y remove findutils --setopt="clean_requirements_on_remove=1" +yum -C -y remove firewalld --setopt="clean_requirements_on_remove=1" echo "Cleaning old yum repodata." commit f7f9910c919cda1ff6e942424fd06105c7d81ad1 Author: Matthew Miller <mattdm@xxxxxxxxxx> Date: Fri Sep 13 13:22:13 2013 -0400 f20 instead of rawhide diff --git a/container/fedora-20-container.ks b/container/fedora-20-container.ks index 1423c9e..a2d9e8d 100644 --- a/container/fedora-20-container.ks +++ b/container/fedora-20-container.ks @@ -7,7 +7,8 @@ # # This kickstart file is designed to be used with appliance-creator and # may need slight modification for use with actual anaconda or other tools. -# We intend to target anaconda-in-a-vm style image building for F20. +# We intend to target anaconda-in-a-vm style image building for F20, but +# not necessarily for containers -- that's yet to be worked out. lang en_US.UTF-8 keyboard us @@ -22,10 +23,8 @@ clearpart --all part / --size 1024 --fstype ext4 # Repositories -#repo --name=fedora --mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=fedora-20&arch=$basearch -#repo --name=fedora-updates --mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=updates-released-f20&arch=$basearch -repo --name=fedora --mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=rawhide&arch=$basearch - +repo --name=fedora --mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=fedora-20&arch=$basearch +repo --name=fedora-updates --mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=updates-released-f20&arch=$basearch reboot _______________________________________________ cloud mailing list cloud@xxxxxxxxxxxxxxxxxxxxxxx https://admin.fedoraproject.org/mailman/listinfo/cloud Fedora Code of Conduct: http://fedoraproject.org/code-of-conduct