Add new LXC: MySQL (#3870)
This commit is contained in:
		
							parent
							
								
									6bee7e291e
								
							
						
					
					
						commit
						eb881fefa6
					
				
							
								
								
									
										70
									
								
								ct/mysql.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								ct/mysql.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,70 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | source <(curl -s https://raw.githubusercontent.com/tteck/Proxmox/main/misc/build.func) | ||||||
|  | # Copyright (c) 2021-2024 tteck | ||||||
|  | # Author: tteck | ||||||
|  | # Co-Author: MickLesk (Canbiz) | ||||||
|  | # License: MIT | ||||||
|  | # https://github.com/tteck/Proxmox/raw/main/LICENSE | ||||||
|  | 
 | ||||||
|  | function header_info { | ||||||
|  | clear | ||||||
|  | cat <<"EOF" | ||||||
|  |     __  ___      _____ ____    __  | ||||||
|  |    /  |/  /_  __/ ___// __ \  / /  | ||||||
|  |   / /|_/ / / / /\__ \/ / / / / /   | ||||||
|  |  / /  / / /_/ /___/ / /_/ / / /___ | ||||||
|  | /_/  /_/\__, //____/\___\_\/_____/ | ||||||
|  |        /____/                      | ||||||
|  | EOF | ||||||
|  | } | ||||||
|  | header_info | ||||||
|  | echo -e "Loading..." | ||||||
|  | APP="MySQL" | ||||||
|  | var_disk="4" | ||||||
|  | var_cpu="1" | ||||||
|  | var_ram="1024" | ||||||
|  | var_os="debian" | ||||||
|  | var_version="12" | ||||||
|  | variables | ||||||
|  | color | ||||||
|  | catch_errors | ||||||
|  | 
 | ||||||
|  | function default_settings() { | ||||||
|  |   CT_TYPE="1" | ||||||
|  |   PW="" | ||||||
|  |   CT_ID=$NEXTID | ||||||
|  |   HN=$NSAPP | ||||||
|  |   DISK_SIZE="$var_disk" | ||||||
|  |   CORE_COUNT="$var_cpu" | ||||||
|  |   RAM_SIZE="$var_ram" | ||||||
|  |   BRG="vmbr0" | ||||||
|  |   NET="dhcp" | ||||||
|  |   GATE="" | ||||||
|  |   APT_CACHER="" | ||||||
|  |   APT_CACHER_IP="" | ||||||
|  |   DISABLEIP6="no" | ||||||
|  |   MTU="" | ||||||
|  |   SD="" | ||||||
|  |   NS="" | ||||||
|  |   MAC="" | ||||||
|  |   VLAN="" | ||||||
|  |   SSH="no" | ||||||
|  |   VERB="no" | ||||||
|  |   echo_default | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function update_script() { | ||||||
|  | header_info | ||||||
|  | if [[ ! -f /usr/share/keyrings/mysql.gpg ]]; then msg_error "No ${APP} Installation Found!"; exit; fi | ||||||
|  | msg_info "Updating ${APP} LXC" | ||||||
|  | apt-get update &>/dev/null | ||||||
|  | apt-get -y upgrade &>/dev/null | ||||||
|  | msg_ok "Updated Successfully" | ||||||
|  | exit | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | start | ||||||
|  | build_container | ||||||
|  | description | ||||||
|  | 
 | ||||||
|  | msg_ok "Completed Successfully!\n" | ||||||
							
								
								
									
										82
									
								
								install/mysql-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								install/mysql-install.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,82 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | 
 | ||||||
|  | # Copyright (c) 2021-2024 tteck | ||||||
|  | # Author: tteck | ||||||
|  | # Co-Author: MickLesk (Canbiz) | ||||||
|  | # License: MIT | ||||||
|  | # https://github.com/tteck/Proxmox/raw/main/LICENSE | ||||||
|  | # Source: https://www.mysql.com/products/community | https://www.phpmyadmin.net | ||||||
|  | 
 | ||||||
|  | source /dev/stdin <<< "$FUNCTIONS_FILE_PATH" | ||||||
|  | color | ||||||
|  | verb_ip6 | ||||||
|  | catch_errors | ||||||
|  | setting_up_container | ||||||
|  | network_check | ||||||
|  | update_os | ||||||
|  | 
 | ||||||
|  | msg_info "Installing Dependencies" | ||||||
|  | $STD apt-get install -y \ | ||||||
|  |   sudo \ | ||||||
|  |   lsb-release \ | ||||||
|  |   curl \ | ||||||
|  |   gnupg   \ | ||||||
|  |   apt-transport-https \ | ||||||
|  |   make \ | ||||||
|  |   mc | ||||||
|  | msg_ok "Installed Dependencies" | ||||||
|  | 
 | ||||||
|  | msg_info "Installing MySQL" | ||||||
|  | curl -fsSL https://repo.mysql.com/RPM-GPG-KEY-mysql-2023 | gpg --dearmor  -o /usr/share/keyrings/mysql.gpg | ||||||
|  | echo "deb [signed-by=/usr/share/keyrings/mysql.gpg] http://repo.mysql.com/apt/debian $(lsb_release -sc) mysql-8.0" >/etc/apt/sources.list.d/mysql.list | ||||||
|  | $STD apt-get update | ||||||
|  | export DEBIAN_FRONTEND=noninteractive | ||||||
|  | $STD apt-get install -y \ | ||||||
|  |   mysql-common \ | ||||||
|  |   mysql-community-client \ | ||||||
|  |   mysql-community-server | ||||||
|  | msg_ok "Installed MySQL" | ||||||
|  | 
 | ||||||
|  | msg_info "Configure MySQL Server" | ||||||
|  | ADMIN_PASS="$(openssl rand -base64 18 | cut -c1-13)" | ||||||
|  | $STD mysql -uroot -p"$ADMIN_PASS" -e "ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '$ADMIN_PASS'; FLUSH PRIVILEGES;" | ||||||
|  | echo "" >>~/mysql.creds | ||||||
|  | echo -e "MySQL Root Password: $ADMIN_PASS" >>~/mysql.creds | ||||||
|  | msg_ok "MySQL Server configured" | ||||||
|  | 
 | ||||||
|  | read -r -p "Would you like to add PhpMyAdmin? <y/N> " prompt | ||||||
|  | if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then | ||||||
|  |   msg_info "Adding phpMyAdmin" | ||||||
|  |   $STD apt-get install -y \ | ||||||
|  |     apache2 \ | ||||||
|  |     php \ | ||||||
|  |     php-mysqli \ | ||||||
|  |     php-mbstring \ | ||||||
|  |     php-zip \ | ||||||
|  |     php-gd \ | ||||||
|  |     php-json \ | ||||||
|  |     php-curl  | ||||||
|  | 	 | ||||||
|  | 	wget -q "https://files.phpmyadmin.net/phpMyAdmin/5.2.1/phpMyAdmin-5.2.1-all-languages.tar.gz" | ||||||
|  | 	mkdir -p /var/www/html/phpMyAdmin | ||||||
|  | 	$STD tar xvf phpMyAdmin-5.2.1-all-languages.tar.gz --strip-components=1 -C /var/www/html/phpMyAdmin | ||||||
|  | 	cp /var/www/html/phpMyAdmin/config.sample.inc.php /var/www/html/phpMyAdmin/config.inc.php | ||||||
|  | 	SECRET=$(openssl rand -base64 32) | ||||||
|  | 	sed -i "s#\$cfg\['blowfish_secret'\] = '';#\$cfg['blowfish_secret'] = '${SECRET}';#" /var/www/html/phpMyAdmin/config.inc.php | ||||||
|  | 	chmod 660 /var/www/html/phpMyAdmin/config.inc.php | ||||||
|  | 	chown -R www-data:www-data /var/www/html/phpMyAdmin | ||||||
|  | 	systemctl restart apache2 | ||||||
|  |   msg_ok "Added phpMyAdmin" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | msg_info "Start Service" | ||||||
|  | systemctl enable -q --now mysql | ||||||
|  | msg_ok "Service started" | ||||||
|  | 
 | ||||||
|  | motd_ssh | ||||||
|  | customize | ||||||
|  | 
 | ||||||
|  | msg_info "Cleaning up" | ||||||
|  | $STD apt-get -y autoremove | ||||||
|  | $STD apt-get -y autoclean | ||||||
|  | msg_ok "Cleaned" | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 CanbiZ
						CanbiZ