Compare commits
3 Commits
43fe76b841
...
testing
Author | SHA1 | Date | |
---|---|---|---|
9977148dd6
|
|||
df45e39d42
|
|||
7ea2454c70
|
@@ -45,7 +45,7 @@ build {
|
|||||||
}
|
}
|
||||||
|
|
||||||
provisioner "shell" {
|
provisioner "shell" {
|
||||||
inline = ["sudo /tmp/debianzfs.sh -ip changeme -P letmeinzfs! /dev/vda debianzfs"]
|
inline = ["sudo /tmp/debianzfs.sh -i -s0 -p changeme -P letmeinzfs! /dev/vda debianzfs"]
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
83
debianzfs.sh
83
debianzfs.sh
@@ -7,25 +7,31 @@
|
|||||||
### Functions ###
|
### Functions ###
|
||||||
#################
|
#################
|
||||||
function usage () {
|
function usage () {
|
||||||
echo "Usage: $(basename "$0") [-ghimpPr] <DISK> [HOSTNAME]"
|
echo "Usage: $(basename "$0") [-ghimpPrs] <DISK> [HOSTNAME]"
|
||||||
echo -e "\t-g\n\t\tMirror GRUB after the installation. Requires: -m"
|
echo -e "\t-g\n\t\tMirror GRUB after the installation. Requires: -m"
|
||||||
echo -e "\n\t-h\n\t\tThe help menu, i.e., the menu you're seeing now."
|
echo -e "\n\t-h\n\t\tThe help menu, i.e., the menu you're seeing now."
|
||||||
echo -e "\n\t-i\n\t\tIgnore the check for the /dev/disk/by-id/* format."
|
echo -e "\n\t-i\n\t\tIgnore the check for the /dev/disk/by-id/* format. You'll likely want: -s"
|
||||||
echo -e "\n\t-m <MIRROR>\n\t\tSet the MIRROR disk for a ZFS mirror installation."
|
echo -e "\n\t-m <MIRROR>\n\t\tSet the MIRROR disk for a ZFS mirror installation."
|
||||||
echo -e "\n\t-p <PASSWORD>\n\t\tSet the password for root. Caution: saves to file temporarily."
|
echo -e "\n\t-p <PASSWORD>\n\t\tSet the password for root. Caution: saves to file temporarily."
|
||||||
echo -e "\n\t-P <PASSWWORD>\n\t\tSet the password for encrypting the root zpool."
|
echo -e "\n\t-P <PASSWWORD>\n\t\tSet the password for encrypting the root zpool."
|
||||||
echo -e "\n\t-r <ZFSROOT>\n\t\tSet the path for the new ZFS chroot. Defaults to /mnt"
|
echo -e "\n\t-r <ZFSROOT>\n\t\tSet the path for the new ZFS chroot. Defaults to /mnt"
|
||||||
|
echo -e "\n\t-s <PARTSUFFIX>\n\t\tSet the partition suffix for disks, defaults to: -part"
|
||||||
|
echo -e "\t\tSet to a zero '0' to remove the suffix entirely, i.e., -s0"
|
||||||
}
|
}
|
||||||
|
|
||||||
function disk_check () {
|
function disk_check () {
|
||||||
DISK_TYPE=$(file "$1" | awk '{ print $2$3 }')
|
local DISK="$1"
|
||||||
|
local DISK_TYPE
|
||||||
|
[ -L "$DISK" ] && DISK=$(readlink -f "$DISK")
|
||||||
|
DISK_TYPE=$(file "$DISK" | awk '{ print $2$3 }')
|
||||||
if [ "$DISK_TYPE" != "blockspecial" ]; then
|
if [ "$DISK_TYPE" != "blockspecial" ]; then
|
||||||
echo "ERROR: Disk '$1' is not a block device"
|
echo "ERROR: Disk '$DISK' is not a block device"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function disk_status () {
|
function disk_status () {
|
||||||
|
local OUTPUT
|
||||||
OUTPUT=$(wipefs "$1")
|
OUTPUT=$(wipefs "$1")
|
||||||
if [ -n "$OUTPUT" ]; then
|
if [ -n "$OUTPUT" ]; then
|
||||||
echo "ERROR: $1 is not empty"
|
echo "ERROR: $1 is not empty"
|
||||||
@@ -35,6 +41,8 @@ function disk_status () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function password_prompt () {
|
function password_prompt () {
|
||||||
|
local password
|
||||||
|
local password_confirm
|
||||||
unset PASSWORD_PROMPT_RESULT
|
unset PASSWORD_PROMPT_RESULT
|
||||||
while true; do
|
while true; do
|
||||||
read -r -s -p "${1}: " password
|
read -r -s -p "${1}: " password
|
||||||
@@ -105,8 +113,8 @@ function create_root_pool () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function part_path () {
|
function part_path () {
|
||||||
DISK="$1"
|
local DISK="$1"
|
||||||
PART="$2"
|
local PART="$2"
|
||||||
[ "$(disk_check "$DISK")" == 1 ] && exit 1
|
[ "$(disk_check "$DISK")" == 1 ] && exit 1
|
||||||
if [ "${DISK:0:7}" == "/dev/sd" ]; then
|
if [ "${DISK:0:7}" == "/dev/sd" ]; then
|
||||||
DISK_PART="${DISK}${PART}"
|
DISK_PART="${DISK}${PART}"
|
||||||
@@ -131,7 +139,7 @@ function mirror_grub () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function disk_byid_check () {
|
function disk_byid_check () {
|
||||||
BYID="/dev/disk/by-id/"
|
local BYID="/dev/disk/by-id/"
|
||||||
if [ ! "${1:0:${#BYID}}" == "$BYID" ]; then
|
if [ ! "${1:0:${#BYID}}" == "$BYID" ]; then
|
||||||
echo "ERROR: DISK needs to be ${BYID}* format"
|
echo "ERROR: DISK needs to be ${BYID}* format"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -146,7 +154,7 @@ export DEBIAN_FRONTEND=noninteractive
|
|||||||
CODENAME="bullseye"
|
CODENAME="bullseye"
|
||||||
|
|
||||||
# Options
|
# Options
|
||||||
while getopts ':ghim:p:P:r:' OPTION; do
|
while getopts ':ghim:p:P:r:s:' OPTION; do
|
||||||
case "$OPTION" in
|
case "$OPTION" in
|
||||||
g) GRUB_MIRROR="true";;
|
g) GRUB_MIRROR="true";;
|
||||||
i) IGNORE_BYID="true";;
|
i) IGNORE_BYID="true";;
|
||||||
@@ -154,6 +162,7 @@ while getopts ':ghim:p:P:r:' OPTION; do
|
|||||||
p) ROOTPW="$OPTARG";;
|
p) ROOTPW="$OPTARG";;
|
||||||
P) RPOOLPW="$OPTARG";;
|
P) RPOOLPW="$OPTARG";;
|
||||||
r) ZFSROOT="$OPTARG";;
|
r) ZFSROOT="$OPTARG";;
|
||||||
|
s) PARTSUFFIX="$OPTARG";;
|
||||||
?)
|
?)
|
||||||
usage
|
usage
|
||||||
exit 1;;
|
exit 1;;
|
||||||
@@ -188,6 +197,12 @@ fi
|
|||||||
# Verify variables
|
# Verify variables
|
||||||
[ -z "$ZFSROOT" ] && ZFSROOT="/mnt"
|
[ -z "$ZFSROOT" ] && ZFSROOT="/mnt"
|
||||||
|
|
||||||
|
if [ -z "$PARTSUFFIX" ]; then
|
||||||
|
PARTSUFFIX="-part"
|
||||||
|
elif [ "$PARTSUFFIX" == "0" ]; then
|
||||||
|
PARTSUFFIX=""
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -z "$DISK" ]; then
|
if [ -z "$DISK" ]; then
|
||||||
echo "ERROR: DISK not set"
|
echo "ERROR: DISK not set"
|
||||||
usage
|
usage
|
||||||
@@ -213,13 +228,16 @@ if [ -z "$RPOOLPW" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$DEBUG" == "true" ]; then
|
if [ "$DEBUG" == "true" ]; then
|
||||||
echo "CODENAME=${CODENAME}"
|
echo "CODENAME='${CODENAME}'"
|
||||||
echo "DISK=${DISK}"
|
echo "DISK='${DISK}'"
|
||||||
echo "ZFSHOST=${ZFSHOST}"
|
echo "ZFSHOST='${ZFSHOST}'"
|
||||||
echo "ZFSROOT=${ZFSROOT}"
|
echo "ZFSROOT='${ZFSROOT}'"
|
||||||
echo "MIRROR=${MIRROR}"
|
echo "MIRROR='${MIRROR}'"
|
||||||
echo "ROOTPW=${ROOTPW}"
|
echo "ROOTPW='${ROOTPW}'"
|
||||||
echo "RPOOLPW=${RPOOLPW}"
|
echo "RPOOLPW='${RPOOLPW}'"
|
||||||
|
echo "PARTSUFFIX='${PARTSUFFIX}'"
|
||||||
|
echo "GRUB_MIRROR='${GRUB_MIRROR}'"
|
||||||
|
echo "IGNORE_BYID='${IGNORE_BYID}'"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Are the DISK paths block devices? AND
|
# Are the DISK paths block devices? AND
|
||||||
@@ -269,23 +287,23 @@ disk_format "$DISK"
|
|||||||
sleep 5
|
sleep 5
|
||||||
|
|
||||||
# Check for partitions 3 and 4
|
# Check for partitions 3 and 4
|
||||||
disk_check "$DISK-part3"
|
disk_check "${DISK}${PARTSUFFIX}3"
|
||||||
disk_check "$DISK-part4"
|
disk_check "${DISK}${PARTSUFFIX}4"
|
||||||
if [ -n "$MIRROR" ]; then
|
if [ -n "$MIRROR" ]; then
|
||||||
disk_check "$MIRROR-part3"
|
disk_check "${DISK}${PARTSUFFIX}3"
|
||||||
disk_check "$MIRROR-part4"
|
disk_check "${DISK}${PARTSUFFIX}4"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 4. Create the boot pool
|
# 4. Create the boot pool
|
||||||
# 5. Create the root pool
|
# 5. Create the root pool
|
||||||
if [ -z "$MIRROR" ]; then
|
if [ -z "$MIRROR" ]; then
|
||||||
create_boot_pool "$ZFSROOT" "$DISK-part3"
|
create_boot_pool "$ZFSROOT" "${DISK}${PARTSUFFIX}3"
|
||||||
create_root_pool "$ZFSROOT" "$DISK-part4" "$RPOOLPW"
|
create_root_pool "$ZFSROOT" "${DISK}${PARTSUFFIX}4" "$RPOOLPW"
|
||||||
else
|
else
|
||||||
create_boot_pool "$ZFSROOT" \
|
create_boot_pool "$ZFSROOT" \
|
||||||
"mirror ${DISK}-part3 $MIRROR-part3"
|
"mirror ${DISK}${PARTSUFFIX}3 ${MIRROR}${PARTSUFFIX}3"
|
||||||
create_root_pool "$ZFSROOT" \
|
create_root_pool "$ZFSROOT" \
|
||||||
"mirror ${DISK}-part4 $MIRROR-part4" "$RPOOLPW"
|
"mirror ${DISK}${PARTSUFFIX}4 ${MIRROR}${PARTSUFFIX}4" "$RPOOLPW"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
###################################
|
###################################
|
||||||
@@ -373,30 +391,27 @@ deb http://deb.debian.org/debian ${CODENAME}-updates main contrib
|
|||||||
deb-src http://deb.debian.org/debian ${CODENAME}-updates main contrib
|
deb-src http://deb.debian.org/debian ${CODENAME}-updates main contrib
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
# 4. Bind the virtual filesystems from the LiveCD environment to the new system and chroot into it
|
|
||||||
# Copy DISK/MIRROR vars under ZFSROOT
|
|
||||||
echo -e "DISK=\"$DISK\"\nROOTPW=\"${ROOTPW}\"" > "$ZFSROOT/var/tmp/zfsenv"
|
|
||||||
|
|
||||||
# Copy self and GRUB mirror helper script into chroot
|
# Copy self and GRUB mirror helper script into chroot
|
||||||
if [ -n "$MIRROR" ]; then
|
if [ -n "$MIRROR" ]; then
|
||||||
cp "$0" "$ZFSROOT/usr/local/bin/debianzfs"
|
cp "$0" "$ZFSROOT/usr/local/bin/debianzfs"
|
||||||
chmod u+x "$ZFSROOT/usr/local/bin/debianzfs"
|
chmod +x "$ZFSROOT/usr/local/bin/debianzfs"
|
||||||
HELPER_SCRIPT="/root/MIRROR_GRUB_POSTINSTALL.sh"
|
HELPER_SCRIPT="/root/MIRROR_GRUB_POSTINSTALL.sh"
|
||||||
cat <<-GRUBMIRROR > "${ZFSROOT}${HELPER_SCRIPT}"
|
cat <<-GRUBMIRROR > "${ZFSROOT}${HELPER_SCRIPT}"
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# Post-install GRUB mirror helper script
|
# Post-install GRUB mirror helper script
|
||||||
/usr/local/bin/debianzfs \
|
/usr/local/bin/debianzfs \
|
||||||
-gm $MIRROR-part2 \
|
-gm ${MIRROR}${PARTSUFFIX}2 \
|
||||||
$DISK-part2)
|
${DISK}${PARTSUFFIX}2
|
||||||
GRUBMIRROR
|
GRUBMIRROR
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Bind
|
# 4. Bind the virtual filesystems from the LiveCD environment to the new system and chroot into it
|
||||||
mount --make-private --rbind /dev /mnt/dev
|
mount --make-private --rbind /dev /mnt/dev
|
||||||
mount --make-private --rbind /proc /mnt/proc
|
mount --make-private --rbind /proc /mnt/proc
|
||||||
mount --make-private --rbind /sys /mnt/sys
|
mount --make-private --rbind /sys /mnt/sys
|
||||||
|
|
||||||
# Chroot
|
# Copy DISK/MIRROR vars under ZFSROOT and chroot
|
||||||
|
echo -e "DISK=\"$DISK\"\nPARTSUFFIX=\"${PARTSUFFIX}\"\nROOTPW=\"${ROOTPW}\"" > "$ZFSROOT/var/tmp/zfsenv"
|
||||||
cat << CHROOT | chroot /mnt bash --login
|
cat << CHROOT | chroot /mnt bash --login
|
||||||
# Setup
|
# Setup
|
||||||
export DEBIAN_FRONTEND=noninteractive
|
export DEBIAN_FRONTEND=noninteractive
|
||||||
@@ -423,9 +438,9 @@ echo REMAKE_INITRD=yes > /etc/dkms/zfs.conf
|
|||||||
# Install GRUB for UEFI booting
|
# Install GRUB for UEFI booting
|
||||||
apt-get install -y dosfstools
|
apt-get install -y dosfstools
|
||||||
|
|
||||||
mkdosfs -F 32 -s 1 -n EFI "\${DISK}-part2"
|
mkdosfs -F 32 -s 1 -n EFI "\${DISK}\${PARTSUFFIX}2"
|
||||||
mkdir /boot/efi
|
mkdir /boot/efi
|
||||||
BLKID_BOOT="/dev/disk/by-uuid/\$(blkid -s UUID -o value \${DISK}-part2)"
|
BLKID_BOOT="/dev/disk/by-uuid/\$(blkid -s UUID -o value \${DISK}\${PARTSUFFIX}2)"
|
||||||
echo "\${BLKID_BOOT} /boot/efi vfat defaults 0 0" >> /etc/fstab
|
echo "\${BLKID_BOOT} /boot/efi vfat defaults 0 0" >> /etc/fstab
|
||||||
mount /boot/efi
|
mount /boot/efi
|
||||||
apt-get install -y grub-efi-amd64 shim-signed
|
apt-get install -y grub-efi-amd64 shim-signed
|
||||||
|
Reference in New Issue
Block a user