mkimage-arch.sh 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. #!/usr/bin/env bash
  2. # Generate a minimal filesystem for archlinux and load it into the local
  3. # docker as "archlinux"
  4. # requires root
  5. set -e
  6. hash pacstrap &>/dev/null || {
  7. echo "Could not find pacstrap. Run pacman -S arch-install-scripts"
  8. exit 1
  9. }
  10. hash expect &>/dev/null || {
  11. echo "Could not find expect. Run pacman -S expect"
  12. exit 1
  13. }
  14. export LANG="C.UTF-8"
  15. ROOTFS=$(mktemp -d ${TMPDIR:-/var/tmp}/rootfs-archlinux-XXXXXXXXXX)
  16. chmod 755 $ROOTFS
  17. # packages to ignore for space savings
  18. PKGIGNORE=(
  19. cryptsetup
  20. device-mapper
  21. dhcpcd
  22. iproute2
  23. jfsutils
  24. linux
  25. lvm2
  26. man-db
  27. man-pages
  28. mdadm
  29. nano
  30. netctl
  31. openresolv
  32. pciutils
  33. pcmciautils
  34. reiserfsprogs
  35. s-nail
  36. systemd-sysvcompat
  37. usbutils
  38. vi
  39. xfsprogs
  40. )
  41. IFS=','
  42. PKGIGNORE="${PKGIGNORE[*]}"
  43. unset IFS
  44. case "$(uname -m)" in
  45. armv*)
  46. if pacman -Q archlinuxarm-keyring >/dev/null 2>&1; then
  47. pacman-key --init
  48. pacman-key --populate archlinuxarm
  49. else
  50. echo "Could not find archlinuxarm-keyring. Please, install it and run pacman-key --populate archlinuxarm"
  51. exit 1
  52. fi
  53. PACMAN_CONF='./mkimage-archarm-pacman.conf'
  54. PACMAN_MIRRORLIST='Server = http://mirror.archlinuxarm.org/$arch/$repo'
  55. PACMAN_EXTRA_PKGS='archlinuxarm-keyring'
  56. EXPECT_TIMEOUT=120
  57. ARCH_KEYRING=archlinuxarm
  58. DOCKER_IMAGE_NAME=archlinuxarm
  59. ;;
  60. *)
  61. PACMAN_CONF='./mkimage-arch-pacman.conf'
  62. PACMAN_MIRRORLIST='Server = https://mirrors.kernel.org/archlinux/$repo/os/$arch'
  63. PACMAN_EXTRA_PKGS=''
  64. EXPECT_TIMEOUT=60
  65. ARCH_KEYRING=archlinux
  66. DOCKER_IMAGE_NAME=archlinux
  67. ;;
  68. esac
  69. export PACMAN_MIRRORLIST
  70. expect <<EOF
  71. set send_slow {1 .1}
  72. proc send {ignore arg} {
  73. sleep .1
  74. exp_send -s -- \$arg
  75. }
  76. set timeout $EXPECT_TIMEOUT
  77. spawn pacstrap -C $PACMAN_CONF -c -d -G -i $ROOTFS base haveged $PACMAN_EXTRA_PKGS --ignore $PKGIGNORE
  78. expect {
  79. -exact "anyway? \[Y/n\] " { send -- "n\r"; exp_continue }
  80. -exact "(default=all): " { send -- "\r"; exp_continue }
  81. -exact "installation? \[Y/n\]" { send -- "y\r"; exp_continue }
  82. }
  83. EOF
  84. arch-chroot $ROOTFS /bin/sh -c 'rm -r /usr/share/man/*'
  85. arch-chroot $ROOTFS /bin/sh -c "haveged -w 1024; pacman-key --init; pkill haveged; pacman -Rs --noconfirm haveged; pacman-key --populate $ARCH_KEYRING; pkill gpg-agent"
  86. arch-chroot $ROOTFS /bin/sh -c "ln -s /usr/share/zoneinfo/UTC /etc/localtime"
  87. echo 'en_US.UTF-8 UTF-8' > $ROOTFS/etc/locale.gen
  88. arch-chroot $ROOTFS locale-gen
  89. arch-chroot $ROOTFS /bin/sh -c 'echo $PACMAN_MIRRORLIST > /etc/pacman.d/mirrorlist'
  90. # udev doesn't work in containers, rebuild /dev
  91. DEV=$ROOTFS/dev
  92. rm -rf $DEV
  93. mkdir -p $DEV
  94. mknod -m 666 $DEV/null c 1 3
  95. mknod -m 666 $DEV/zero c 1 5
  96. mknod -m 666 $DEV/random c 1 8
  97. mknod -m 666 $DEV/urandom c 1 9
  98. mkdir -m 755 $DEV/pts
  99. mkdir -m 1777 $DEV/shm
  100. mknod -m 666 $DEV/tty c 5 0
  101. mknod -m 600 $DEV/console c 5 1
  102. mknod -m 666 $DEV/tty0 c 4 0
  103. mknod -m 666 $DEV/full c 1 7
  104. mknod -m 600 $DEV/initctl p
  105. mknod -m 666 $DEV/ptmx c 5 2
  106. ln -sf /proc/self/fd $DEV/fd
  107. tar --numeric-owner --xattrs --acls -C $ROOTFS -c . | docker import - $DOCKER_IMAGE_NAME
  108. docker run --rm -t $DOCKER_IMAGE_NAME echo Success.
  109. rm -rf $ROOTFS