mirror of
https://github.com/bashclub/zamba-lxc-toolbox.git
synced 2024-12-25 19:50:12 +01:00
206 lines
6.3 KiB
Bash
Executable File
206 lines
6.3 KiB
Bash
Executable File
#!/bin/bash
|
|
set -euo pipefail
|
|
|
|
# This script will create and fire up a standard debian buster lxc container on your Proxmox VE.
|
|
# On a Proxmox cluster, the script will create the container on the local node, where it's executed.
|
|
# The container ID will be automatically assigned by increasing (+1) the highest number of
|
|
# existing LXC containers in your environment. If the assigned ID is already taken by a VM
|
|
# or no containers exist yet, the script falls back to the ID 100.
|
|
|
|
# Authors:
|
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
|
|
|
# IMPORTANT NOTE:
|
|
# Please adjust th settings in 'zamba.conf' to your needs before running the script
|
|
|
|
############### ZAMBA INSTALL SCRIPT ###############
|
|
prog="$(basename $0)"
|
|
|
|
usage() {
|
|
cat >&2 <<-EOF
|
|
usage: $prog [-h] [-d] [-i CTID] [-s SERVICE] [-c CFGFILE]
|
|
installs a preconfigured lxc container on your proxmox server
|
|
-i CTID provide a container id instead of auto detection
|
|
-s SERVICE provide the service name and skip the selection dialog
|
|
-c CFGFILE use a different config file than 'zamba.conf'
|
|
-d Debug mode inside LXC container
|
|
-h displays this help text
|
|
---------------------------------------------------------------------------
|
|
(C) 2021 zamba-lxc-toolbox by bashclub (https://github.com/bashclub)
|
|
---------------------------------------------------------------------------
|
|
|
|
EOF
|
|
exit $1
|
|
}
|
|
|
|
ctid=0
|
|
service=ask
|
|
config=$PWD/conf/zamba.conf
|
|
debug=0
|
|
|
|
while getopts "hi:s:c:d" opt; do
|
|
case $opt in
|
|
h) usage 0 ;;
|
|
i) ctid=$OPTARG ;;
|
|
s) service=$OPTARG ;;
|
|
c) config=$OPTARG ;;
|
|
d) debug=1 ;;
|
|
*) usage 1 ;;
|
|
esac
|
|
done
|
|
shift $((OPTIND-1))
|
|
|
|
OPTS=$(find src/ -maxdepth 1 -mindepth 1 -type d -exec basename -a {} + | sort -n)
|
|
|
|
valid=0
|
|
if [[ "$service" == "ask" ]]; then
|
|
select svc in $OPTS quit; do
|
|
if [[ "$svc" != "quit" ]]; then
|
|
for line in $OPTS; do
|
|
if [[ "$svc" == "$line" ]]; then
|
|
service=$svc
|
|
echo "Installation of $service selected."
|
|
valid=1
|
|
break
|
|
fi
|
|
done
|
|
else
|
|
echo "Selected 'quit' exiting without action..."
|
|
exit 0
|
|
fi
|
|
if [[ "$valid" == "1" ]]; then
|
|
break
|
|
fi
|
|
done
|
|
else
|
|
for line in $OPTS; do
|
|
if [[ "$service" == "$line" ]]; then
|
|
echo "Installation of $service selected."
|
|
valid=1
|
|
break
|
|
fi
|
|
done
|
|
fi
|
|
|
|
if [[ "$valid" != "1" ]]; then
|
|
echo "Invalid option, exiting..."
|
|
usage 1
|
|
fi
|
|
|
|
# Load configuration file
|
|
echo "Loading config file '$config'..."
|
|
if [ ! -e "$config" ]; then
|
|
echo "Configuration files does not exist"
|
|
exit 1
|
|
fi
|
|
|
|
source "src/functions.sh"
|
|
|
|
source "$config"
|
|
|
|
source "$PWD/src/$service/constants-service.conf"
|
|
|
|
if [ $LXC_MEM -lt $LXC_MEM_MIN ]; then
|
|
LXC_MEM=$LXC_MEM_MIN
|
|
fi
|
|
|
|
if [ $LXC_AUTOTAG -gt 0 ]; then
|
|
TAGS="--tags ${LXC_TAGS},${SERVICE_TAGS}"
|
|
fi
|
|
|
|
# Check is the newest template available, else download it.
|
|
pveam update
|
|
TMPL_NAME=$(pveam available --section system | grep $LXC_TEMPLATE_VERSION | tail -1 | cut -d' ' -f11)
|
|
pveam download $LXC_TEMPLATE_STORAGE $TMPL_NAME
|
|
|
|
if [ $ctid -gt 99 ]; then
|
|
LXC_CHK=$ctid
|
|
else
|
|
# Get next free LXC-number
|
|
LXC_CHK=$(($(pct list | cut -d' ' -f1 | tail -1) + 1))
|
|
fi
|
|
|
|
if [ $LXC_CHK -lt 100 ] || [ -f /etc/pve/qemu-server/$LXC_CHK.conf ]; then
|
|
LXC_NBR=$(pvesh get /cluster/nextid);
|
|
else
|
|
LXC_NBR=$LXC_CHK;
|
|
fi
|
|
echo "Will now create LXC Container $LXC_NBR!";
|
|
|
|
if [ $LXC_THREADS -gt 0 ]; then
|
|
LXC_CORES=--cores\ $LXC_THREADS
|
|
fi
|
|
|
|
|
|
if [[ $LXC_RESSOURCE_POOL != "" ]]; then
|
|
LXC_POOL=--pool\ $LXC_RESSOURCE_POOL
|
|
fi
|
|
|
|
|
|
# Create the container
|
|
set +u
|
|
pct create $LXC_NBR $TAGS $LXC_CORES $LXC_POOL --password $LXC_PWD -unprivileged $LXC_UNPRIVILEGED $LXC_TEMPLATE_STORAGE:vztmpl/$TMPL_NAME -rootfs $LXC_ROOTFS_STORAGE:$LXC_ROOTFS_SIZE,acl=1;
|
|
set -u
|
|
sleep 2;
|
|
|
|
# Check vlan configuration
|
|
if [[ $LXC_VLAN != "NONE" ]];then VLAN=",tag=$LXC_VLAN"; else VLAN=""; fi
|
|
# Reconfigure conatiner
|
|
pct set $LXC_NBR -memory $LXC_MEM -swap $LXC_SWAP -hostname $LXC_HOSTNAME -onboot 1 -timezone $LXC_TIMEZONE -features nesting=$LXC_NESTING,keyctl=$LXC_KEYCTL;
|
|
if [ $LXC_DHCP == true ]; then
|
|
pct set $LXC_NBR -net0 "name=eth0,bridge=$LXC_BRIDGE,ip=dhcp,type=veth$VLAN"
|
|
else
|
|
pct set $LXC_NBR -net0 "name=eth0,bridge=$LXC_BRIDGE,firewall=1,gw=$LXC_GW,ip=$LXC_IP,type=veth$VLAN" -nameserver $LXC_DNS -searchdomain $LXC_DOMAIN
|
|
fi
|
|
|
|
sleep 2
|
|
|
|
if [ $LXC_MP -gt 0 ]; then
|
|
pct set $LXC_NBR -mp0 $LXC_SHAREFS_STORAGE:$LXC_SHAREFS_SIZE,backup=1,mp=/$LXC_SHAREFS_MOUNTPOINT
|
|
if [[ "$(pvesm status | grep $LXC_SHAREFS_STORAGE | cut -d ' ' -f6)" == "zfspool" ]]; then
|
|
pool=$(grep -A 4 $LXC_SHAREFS_STORAGE /etc/pve/storage.cfg | grep -m1 "pool " | cut -d ' ' -f2)
|
|
dataset=$(grep mp0 /etc/pve/lxc/$LXC_NBR.conf | cut -d ':' -f3 | cut -d',' -f1)
|
|
zfs set recordsize=$LXC_MP_RECORDSIZE $pool/$dataset
|
|
fi
|
|
fi
|
|
|
|
sleep 2;
|
|
|
|
PS3="Select the Server-Function: "
|
|
|
|
pct start $LXC_NBR;
|
|
sleep 5;
|
|
# Set the root ssh key
|
|
pct exec $LXC_NBR -- mkdir -p /root/.ssh
|
|
pct push $LXC_NBR $LXC_AUTHORIZED_KEY /root/.ssh/authorized_keys
|
|
pct push $LXC_NBR "$config" /root/zamba.conf
|
|
pct exec $LXC_NBR -- sed -i "s,\${service},${service}," /root/zamba.conf
|
|
pct exec $LXC_NBR -- echo "LXC_NBR=$LXC_NBR" /root/zamba.conf
|
|
pct push $LXC_NBR "$PWD/src/functions.sh" /root/functions.sh
|
|
pct push $LXC_NBR "$PWD/src/constants.conf" /root/constants.conf
|
|
pct push $LXC_NBR "$PWD/src/lxc-base.sh" /root/lxc-base.sh
|
|
pct push $LXC_NBR "$PWD/src/$service/install-service.sh" /root/install-service.sh
|
|
pct push $LXC_NBR "$PWD/src/$service/constants-service.conf" /root/constants-service.conf
|
|
|
|
if [ $debug -gt 0 ]; then dbg=-vx; else dbg=""; fi
|
|
|
|
echo "Installing basic container setup..."
|
|
pct exec $LXC_NBR -- su - root -c "bash $dbg /root/lxc-base.sh"
|
|
echo "Install '$service'!"
|
|
pct exec $LXC_NBR -- su - root -c "bash $dbg /root/install-service.sh"
|
|
|
|
pct shutdown $LXC_NBR
|
|
if [[ $service == "zmb-ad" ]]; then
|
|
## set nameserver, ${LXC_IP%/*} extracts the ip address from cidr format
|
|
pct set $LXC_NBR -nameserver ${LXC_IP%/*}
|
|
elif [[ $service == "zmb-ad-join" ]]; then
|
|
pct set $LXC_NBR -nameserver "${LXC_IP%/*} $LXC_DNS"
|
|
fi
|
|
pct start $LXC_NBR
|
|
if [[ $service == "zmb-ad" ]] || [[ $service == "zmb-ad-join" ]]; then
|
|
sleep 5
|
|
pct exec $LXC_NBR /usr/local/bin/smb-backup 7
|
|
fi
|