mkimage-arch.sh 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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. arch="$(uname -m)"
  45. case "$arch" in
  46. armv*)
  47. if pacman -Q archlinuxarm-keyring >/dev/null 2>&1; then
  48. pacman-key --init
  49. pacman-key --populate archlinuxarm
  50. else
  51. echo "Could not find archlinuxarm-keyring. Please, install it and run pacman-key --populate archlinuxarm"
  52. exit 1
  53. fi
  54. PACMAN_CONF=$(mktemp ${TMPDIR:-/var/tmp}/pacman-conf-archlinux-XXXXXXXXX)
  55. version="$(echo $arch | cut -c 5)"
  56. sed "s/Architecture = armv/Architecture = armv${version}h/g" './mkimage-archarm-pacman.conf' > "${PACMAN_CONF}"
  57. PACMAN_MIRRORLIST='Server = http://mirror.archlinuxarm.org/$arch/$repo'
  58. PACMAN_EXTRA_PKGS='archlinuxarm-keyring'
  59. EXPECT_TIMEOUT=1800 # Most armv* based devices can be very slow (e.g. RPiv1)
  60. ARCH_KEYRING=archlinuxarm
  61. DOCKER_IMAGE_NAME="armv${version}h/archlinux"
  62. ;;
  63. *)
  64. PACMAN_CONF='./mkimage-arch-pacman.conf'
  65. PACMAN_MIRRORLIST='Server = https://mirrors.kernel.org/archlinux/$repo/os/$arch'
  66. PACMAN_EXTRA_PKGS=''
  67. EXPECT_TIMEOUT=60
  68. ARCH_KEYRING=archlinux
  69. DOCKER_IMAGE_NAME=archlinux
  70. ;;
  71. esac
  72. export PACMAN_MIRRORLIST
  73. expect <<EOF
  74. set send_slow {1 .1}
  75. proc send {ignore arg} {
  76. sleep .1
  77. exp_send -s -- \$arg
  78. }
  79. set timeout $EXPECT_TIMEOUT
  80. spawn pacstrap -C $PACMAN_CONF -c -d -G -i $ROOTFS base haveged $PACMAN_EXTRA_PKGS --ignore $PKGIGNORE
  81. expect {
  82. -exact "anyway? \[Y/n\] " { send -- "n\r"; exp_continue }
  83. -exact "(default=all): " { send -- "\r"; exp_continue }
  84. -exact "installation? \[Y/n\]" { send -- "y\r"; exp_continue }
  85. -exact "delete it? \[Y/n\]" { send -- "y\r"; exp_continue }
  86. }
  87. EOF
  88. arch-chroot $ROOTFS /bin/sh -c 'rm -r /usr/share/man/*'
  89. 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"
  90. arch-chroot $ROOTFS /bin/sh -c "ln -s /usr/share/zoneinfo/UTC /etc/localtime"
  91. echo 'en_US.UTF-8 UTF-8' > $ROOTFS/etc/locale.gen
  92. arch-chroot $ROOTFS locale-gen
  93. arch-chroot $ROOTFS /bin/sh -c 'echo $PACMAN_MIRRORLIST > /etc/pacman.d/mirrorlist'
  94. # udev doesn't work in containers, rebuild /dev
  95. DEV=$ROOTFS/dev
  96. rm -rf $DEV
  97. mkdir -p $DEV
  98. mknod -m 666 $DEV/null c 1 3
  99. mknod -m 666 $DEV/zero c 1 5
  100. mknod -m 666 $DEV/random c 1 8
  101. mknod -m 666 $DEV/urandom c 1 9
  102. mkdir -m 755 $DEV/pts
  103. mkdir -m 1777 $DEV/shm
  104. mknod -m 666 $DEV/tty c 5 0
  105. mknod -m 600 $DEV/console c 5 1
  106. mknod -m 666 $DEV/tty0 c 4 0
  107. mknod -m 666 $DEV/full c 1 7
  108. mknod -m 600 $DEV/initctl p
  109. mknod -m 666 $DEV/ptmx c 5 2
  110. ln -sf /proc/self/fd $DEV/fd
  111. tar --numeric-owner --xattrs --acls -C $ROOTFS -c . | docker import - $DOCKER_IMAGE_NAME
  112. docker run --rm -t $DOCKER_IMAGE_NAME echo Success.
  113. rm -rf $ROOTFS