mariadb-v1.sh 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. #!/usr/bin/env bash
  2. while true; do
  3. read -p "This will create a New Mariadb LXC Container. Proceed(y/n)?" yn
  4. case $yn in
  5. [Yy]* ) break;;
  6. [Nn]* ) exit;;
  7. * ) echo "Please answer yes or no.";;
  8. esac
  9. done
  10. clear
  11. set -o errexit
  12. set -o errtrace
  13. set -o nounset
  14. set -o pipefail
  15. shopt -s expand_aliases
  16. alias die='EXIT=$? LINE=$LINENO error_exit'
  17. BL=`echo "\033[36m"`
  18. CM='\xE2\x9C\x94\033'
  19. GN=`echo "\033[1;92m"`
  20. CL=`echo "\033[m"`
  21. trap die ERR
  22. trap cleanup EXIT
  23. function error_exit() {
  24. trap - ERR
  25. local DEFAULT='Unknown failure occured.'
  26. local REASON="\e[97m${1:-$DEFAULT}\e[39m"
  27. local FLAG="\e[91m[ERROR] \e[93m$EXIT@$LINE"
  28. msg "$FLAG $REASON"
  29. [ ! -z ${CTID-} ] && cleanup_ctid
  30. exit $EXIT
  31. }
  32. function warn() {
  33. local REASON="\e[97m$1\e[39m"
  34. local FLAG="\e[93m[WARNING]\e[39m"
  35. msg "$FLAG $REASON"
  36. }
  37. function info() {
  38. local REASON="$1"
  39. local FLAG="\e[36m[INFO]\e[39m"
  40. msg "$FLAG $REASON"
  41. }
  42. function msg() {
  43. local TEXT="$1"
  44. echo -e "$TEXT"
  45. }
  46. function cleanup_ctid() {
  47. if [ ! -z ${MOUNT+x} ]; then
  48. pct unmount $CTID
  49. fi
  50. if $(pct status $CTID &>/dev/null); then
  51. if [ "$(pct status $CTID | awk '{print $2}')" == "running" ]; then
  52. pct stop $CTID
  53. fi
  54. pct destroy $CTID
  55. elif [ "$(pvesm list $STORAGE --vmid $CTID)" != "" ]; then
  56. pvesm free $ROOTFS
  57. fi
  58. }
  59. function cleanup() {
  60. popd >/dev/null
  61. rm -rf $TEMP_DIR
  62. }
  63. function load_module() {
  64. if ! $(lsmod | grep -Fq $1); then
  65. modprobe $1 &>/dev/null || \
  66. die "Failed to load '$1' module."
  67. fi
  68. MODULES_PATH=/etc/modules
  69. if ! $(grep -Fxq "$1" $MODULES_PATH); then
  70. echo "$1" >> $MODULES_PATH || \
  71. die "Failed to add '$1' module to load at boot."
  72. fi
  73. }
  74. TEMP_DIR=$(mktemp -d)
  75. pushd $TEMP_DIR >/dev/null
  76. wget -qL https://raw.githubusercontent.com/tteck/Proxmox/main/setup/mariadb_setup.sh
  77. load_module overlay
  78. while read -r line; do
  79. TAG=$(echo $line | awk '{print $1}')
  80. TYPE=$(echo $line | awk '{printf "%-10s", $2}')
  81. FREE=$(echo $line | numfmt --field 4-6 --from-unit=K --to=iec --format %.2f | awk '{printf( "%9sB", $6)}')
  82. ITEM=" Type: $TYPE Free: $FREE "
  83. OFFSET=2
  84. if [[ $((${#ITEM} + $OFFSET)) -gt ${MSG_MAX_LENGTH:-} ]]; then
  85. MSG_MAX_LENGTH=$((${#ITEM} + $OFFSET))
  86. fi
  87. STORAGE_MENU+=( "$TAG" "$ITEM" "OFF" )
  88. done < <(pvesm status -content rootdir | awk 'NR>1')
  89. if [ $((${#STORAGE_MENU[@]}/3)) -eq 0 ]; then
  90. warn "'Container' needs to be selected for at least one storage location."
  91. die "Unable to detect valid storage location."
  92. elif [ $((${#STORAGE_MENU[@]}/3)) -eq 1 ]; then
  93. STORAGE=${STORAGE_MENU[0]}
  94. else
  95. while [ -z "${STORAGE:+x}" ]; do
  96. STORAGE=$(whiptail --title "Storage Pools" --radiolist \
  97. "Which storage pool you would like to use for the container?\n\n" \
  98. 16 $(($MSG_MAX_LENGTH + 23)) 6 \
  99. "${STORAGE_MENU[@]}" 3>&1 1>&2 2>&3) || exit
  100. done
  101. fi
  102. info "Using ${BL}${STORAGE}${CL} for Storage Location."
  103. CTID=$(pvesh get /cluster/nextid)
  104. info "Container ID is ${BL}${CTID}${CL}."
  105. echo -en "${GN} Updating LXC Template List... "
  106. pveam update >/dev/null
  107. echo -e "${CM}${CL} \r"
  108. echo -en "${GN} Downloading LXC Template... "
  109. OSTYPE=debian
  110. OSVERSION=${OSTYPE}-11
  111. mapfile -t TEMPLATES < <(pveam available -section system | sed -n "s/.*\($OSVERSION.*\)/\1/p" | sort -t - -k 2 -V)
  112. TEMPLATE="${TEMPLATES[-1]}"
  113. pveam download local $TEMPLATE >/dev/null ||
  114. die "A problem occured while downloading the LXC template."
  115. STORAGE_TYPE=$(pvesm status -storage $STORAGE | awk 'NR>1 {print $2}')
  116. case $STORAGE_TYPE in
  117. dir|nfs)
  118. DISK_EXT=".raw"
  119. DISK_REF="$CTID/"
  120. ;;
  121. zfspool)
  122. DISK_PREFIX="subvol"
  123. DISK_FORMAT="subvol"
  124. ;;
  125. esac
  126. DISK=${DISK_PREFIX:-vm}-${CTID}-disk-0${DISK_EXT-}
  127. ROOTFS=${STORAGE}:${DISK_REF-}${DISK}
  128. echo -e "${CM}${CL} \r"
  129. echo -en "${GN} Creating LXC Container... "
  130. DISK_SIZE=4G
  131. pvesm alloc $STORAGE $CTID $DISK $DISK_SIZE --format ${DISK_FORMAT:-raw} >/dev/null
  132. if [ "$STORAGE_TYPE" == "zfspool" ]; then
  133. warn "Some containers may not work properly due to ZFS not supporting 'fallocate'."
  134. else
  135. mkfs.ext4 $(pvesm path $ROOTFS) &>/dev/null
  136. fi
  137. ARCH=$(dpkg --print-architecture)
  138. HOSTNAME=mariadb
  139. TEMPLATE_STRING="local:vztmpl/${TEMPLATE}"
  140. pct create $CTID $TEMPLATE_STRING -arch $ARCH -features nesting=1 \
  141. -hostname $HOSTNAME -net0 name=eth0,bridge=vmbr0,ip=dhcp -onboot 1 -cores 1 -memory 1024 \
  142. -ostype $OSTYPE -rootfs $ROOTFS,size=$DISK_SIZE -storage $STORAGE >/dev/null
  143. MOUNT=$(pct mount $CTID | cut -d"'" -f 2)
  144. ln -fs $(readlink /etc/localtime) ${MOUNT}/etc/localtime
  145. pct unmount $CTID && unset MOUNT
  146. echo -e "${CM}${CL} \r"
  147. echo -en "${GN} Starting LXC Container... "
  148. pct start $CTID
  149. pct push $CTID mariadb_setup.sh /mariadb_setup.sh -perms 755
  150. echo -e "${CM}${CL} \r"
  151. pct exec $CTID /mariadb_setup.sh
  152. IP=$(pct exec $CTID ip a s dev eth0 | sed -n '/inet / s/\// /p' | awk '{print $2}')
  153. info "${GN} Successfully created a MariaDB LXC Container to ${BL}${CTID}${CL}"
  154. echo -e "${CL} Adminer should be reachable by going to the following URL.
  155. ${BL} http://${IP}/adminer/ ${CL}"