aea7852733
- Better stats for updates. - Option to skip stats for custom versions. - Now we can update from an specific branch.
583 lines
22 KiB
Bash
583 lines
22 KiB
Bash
#!/bin/bash
|
|
source /opt/webinoly/lib/general
|
|
|
|
|
|
app_version() {
|
|
local app_ver="1.6.0-beta"
|
|
echo $app_ver
|
|
}
|
|
svr_version() {
|
|
local ser_ver="1.2"
|
|
echo $ser_ver
|
|
}
|
|
|
|
|
|
# Remove Intallation Files
|
|
app_purge() {
|
|
sudo rm $HOME/webinoly.tar
|
|
sudo rm -rf /opt/webinoly/plugins
|
|
}
|
|
|
|
|
|
set_timezone() {
|
|
if [[ -n $(conf_read timezone) ]] && grep -Fxq $(conf_read timezone) /opt/webinoly/lib/timezone.dat; then
|
|
[[ $1 == "os" || $1 == "all" ]] && sudo timedatectl set-timezone $(conf_read timezone)
|
|
# It's not compatible with multi-php feature.
|
|
if [[ ($1 == "php" || $1 == "all") && $(conf_read php) == "true" ]]; then
|
|
sudo sed -i "/date.timezone =/c\date.timezone = $(conf_read timezone)" /etc/php/$(conf_read php-ver)/fpm/php.ini
|
|
sudo service php*-fpm reload
|
|
fi
|
|
echo "${gre}Timezone: $(conf_read timezone) ${end}"
|
|
else
|
|
conf_delete timezone
|
|
echo "${red}Timezone not found or not valid!${end}"
|
|
fi
|
|
}
|
|
|
|
|
|
linux_optim() {
|
|
api-events_update in4
|
|
if [[ $(conf_read linux-optim) == "true" ]]; then
|
|
exit 1
|
|
fi
|
|
|
|
if [[ -n $(conf_read fd-ratio) && $(conf_read fd-ratio) =~ ^[0-9]+$ && $(conf_read fd-ratio) -le "100" ]]; then
|
|
local fdratio=$(conf_read fd-ratio)
|
|
else
|
|
local fdratio="30"
|
|
fi
|
|
if [[ -n $(conf_read nginx-fd-ratio) && $(conf_read nginx-fd-ratio) =~ ^[0-9]+$ && $(conf_read nginx-fd-ratio) -le "100" ]]; then
|
|
local nginxfdratio=$(conf_read nginx-fd-ratio)
|
|
else
|
|
local nginxfdratio="65"
|
|
fi
|
|
if [[ -n $(conf_read max-mb-uploads) && $(conf_read max-mb-uploads) =~ ^[0-9]+$ ]]; then
|
|
local maxuploads=$(conf_read max-mb-uploads)
|
|
else
|
|
local maxuploads="50"
|
|
fi
|
|
|
|
local ramkb=$(grep MemTotal /proc/meminfo | cut -f 2 -d ':' | tr -d ' ' | cut -f 1 -d 'k')
|
|
local newfd=$((($ramkb*$fdratio)/100))
|
|
local nginxfd=$((($newfd*$nginxfdratio)/100))
|
|
local cachefd=$(($nginxfd/3))
|
|
local cacheram=$(($nginxfd/1024))
|
|
sudo sysctl -w fs.file-max=$newfd
|
|
[ -d /etc/systemd/system/nginx.service.d ] || sudo mkdir /etc/systemd/system/nginx.service.d
|
|
[ -a /etc/systemd/system/nginx.service.d/nofile_limit.conf ] || sudo touch /etc/systemd/system/nginx.service.d/nofile_limit.conf
|
|
sudo echo "[Service]
|
|
LimitNOFILE=$nginxfd" | tee -a /etc/systemd/system/nginx.service.d/nofile_limit.conf
|
|
|
|
sudo sed -i "/worker_rlimit_nofile/c \worker_rlimit_nofile $nginxfd;" /etc/nginx/nginx.conf
|
|
sudo sed -i "/client_max_body_size/c \ client_max_body_size ${maxuploads}m;" /etc/nginx/nginx.conf
|
|
sudo sed -i "/open_file_cache max/c \ open_file_cache max=$cachefd inactive=5m;" /etc/nginx/nginx.conf
|
|
sudo sed -i "/fastcgi_cache_path/c \fastcgi_cache_path /var/run/nginx-cache levels=1:2 keys_zone=WORDPRESS:50m max_size=${cacheram}m inactive=7d;" /etc/nginx/conf.d/fastcgi.conf
|
|
#mkdir -p /var/run/nginx-cache
|
|
#echo "tmpfs /var/run/nginx-cache tmpfs size=${cacheram}M,mode=0744,uid=www-data,gid=www-data 0 0" | sudo tee -a /etc/fstab
|
|
#sudo mount /var/run/nginx-cache
|
|
|
|
sudo echo "# WebinolyStart - Don't delete
|
|
fs.file-max = $newfd
|
|
fs.nr_open=12000000
|
|
vm.min_free_kbytes=65536
|
|
net.core.somaxconn = 65536
|
|
net.core.wmem_max=16777216
|
|
net.core.rmem_max=16777216
|
|
net.core.netdev_max_backlog=8192
|
|
net.core.optmem_max=8192
|
|
net.ipv4.ip_local_port_range=1024 65535
|
|
net.ipv4.icmp_echo_ignore_broadcasts = 1
|
|
net.ipv4.icmp_ignore_bogus_error_responses = 1
|
|
net.ipv4.tcp_max_tw_buckets = 1440000
|
|
net.ipv4.tcp_window_scaling = 1
|
|
net.ipv4.tcp_max_syn_backlog = 3240000
|
|
net.ipv4.tcp_rmem=8192 87380 16777216
|
|
net.ipv4.tcp_wmem=8192 65536 16777216
|
|
net.ipv4.tcp_fin_timeout=10
|
|
net.ipv4.tcp_keepalive_intvl=30
|
|
net.ipv4.tcp_keepalive_probes=3
|
|
net.ipv4.tcp_keepalive_time=240
|
|
net.ipv4.tcp_sack=1
|
|
net.ipv4.tcp_syn_retries=3
|
|
net.ipv4.tcp_synack_retries = 2
|
|
net.ipv4.tcp_tw_recycle = 0
|
|
net.ipv4.tcp_tw_reuse = 0
|
|
net.ipv4.tcp_slow_start_after_idle=0
|
|
net.ipv4.tcp_rfc1337=1
|
|
net.ipv4.tcp_challenge_ack_limit = 999999999
|
|
net.ipv4.tcp_mtu_probing = 1
|
|
net.ipv4.tcp_base_mss = 1024
|
|
net.ipv4.conf.all.accept_redirects = 0
|
|
net.ipv4.conf.all.accept_source_route = 0
|
|
net.ipv4.conf.all.log_martians = 1
|
|
net.ipv4.conf.all.rp_filter = 1
|
|
net.ipv4.conf.all.secure_redirects = 0
|
|
net.ipv4.conf.all.send_redirects = 0
|
|
net.ipv4.conf.default.accept_redirects = 0
|
|
net.ipv4.conf.default.accept_source_route = 0
|
|
net.ipv4.conf.default.log_martians = 1
|
|
net.ipv4.conf.default.rp_filter = 1
|
|
net.ipv4.conf.default.secure_redirects = 0
|
|
net.ipv4.conf.default.send_redirects = 0
|
|
# WebinolyEnd" | tee -a /etc/sysctl.conf
|
|
|
|
# https://www.cyberciti.biz/faq/linux-increase-the-maximum-number-of-open-files/
|
|
# https://ospi.fi/blog/centos-7-raise-nofile-limit-for-nginx.html
|
|
# https://www.masv.io/boost-nginx-connection-limits/
|
|
# https://underyx.me/2015/05/18/raising-the-maximum-number-of-file-descriptors
|
|
# sudo cat /proc/$(cat /run/nginx.pid)/limits - ver los recursos actuales del proceso main de nginx
|
|
# sudo ps aux | grep nginx --- ver todos lo procesos corriendo con nginx user
|
|
sudo sed -i "/End of file/i \# WebinolyStart - Don't delete" /etc/security/limits.conf
|
|
sudo sed -i '/End of file/i \root - nofile 4096' /etc/security/limits.conf
|
|
sudo sed -i '/End of file/i \* - nofile 4096' /etc/security/limits.conf
|
|
sudo sed -i "/End of file/i \# WebinolyEnd" /etc/security/limits.conf
|
|
|
|
swap_create
|
|
set_timezone os
|
|
|
|
sudo sysctl -p -q
|
|
sudo systemctl daemon-reload
|
|
sudo kill $(cat /run/nginx.pid)
|
|
conf_write linux-optim true
|
|
sudo nginx -t && sudo service nginx start
|
|
api-events_update in7
|
|
}
|
|
|
|
|
|
linux_purge() {
|
|
if [[ $(conf_read linux-optim) == "true" ]]; then
|
|
api-events_update pn7
|
|
sudo sed -i '/WebinolyStart/,/WebinolyEnd/{/.*/d}' /etc/security/limits.conf
|
|
sudo sed -i '/WebinolyStart/,/WebinolyEnd/{/.*/d}' /etc/sysctl.conf
|
|
sudo rm -rf /etc/systemd/system/nginx.service.d
|
|
sudo sed -i '/\/var\/run\/nginx-cache/d' /etc/fstab
|
|
#sudo umount /var/run/nginx-cache
|
|
sudo sysctl -p -q
|
|
sudo systemctl daemon-reload
|
|
conf_write linux-optim purged
|
|
api-events_update pn8
|
|
fi
|
|
}
|
|
|
|
|
|
messagend_install() {
|
|
echo "${gre}"
|
|
echo ""
|
|
echo "*****************************************************************************************"
|
|
echo "************ INSTALLATION HAS FINISHED SUCCESSFULLY ************"
|
|
echo "*****************************************************************************************${end}"
|
|
if [[ $1 == "dbpass" ]]; then
|
|
local rootpass=$( echo $(conf_read mysql-root) | openssl enc -d -a -salt )
|
|
local adminpass=$( echo $(conf_read mysql-admin) | openssl enc -d -a -salt )
|
|
echo "${gre}*****************************************************************************************"
|
|
echo "************ Save your DB access password in a secure place: ************"
|
|
echo "************ root: ${rootpass} admin: ${adminpass} ************"
|
|
echo "*****************************************************************************************"
|
|
echo "${end}"
|
|
fi
|
|
}
|
|
|
|
|
|
nginx_install() {
|
|
api-events_update in1
|
|
pre_install
|
|
if [[ ($(conf_read nginx-ppa) == "mainline" || $value == "mainline") && $value != "stable" ]]; then
|
|
echo | sudo add-apt-repository ppa:nginx/development
|
|
conf_write nginx-ppa mainline
|
|
else
|
|
echo | sudo add-apt-repository ppa:nginx/stable
|
|
conf_write nginx-ppa stable
|
|
fi
|
|
pre_install
|
|
sudo apt-get -y install nginx
|
|
|
|
if [[ $(conf_read login-www-data) == "true" ]]; then
|
|
sudo chown -R www-data:www-data /var/www
|
|
sudo chown root:root /var/www
|
|
fi
|
|
|
|
sudo nginx -t && sudo service nginx start
|
|
conf_write nginx true
|
|
echo "${gre}Nginx has been installed successfully! ${end}"
|
|
api-events_update in2
|
|
}
|
|
|
|
|
|
php_install() {
|
|
api-events_update ip1
|
|
if [[ -n $(conf_read php-ver) && ($(conf_read php-ver) == "7.2" || $(conf_read php-ver) == "7.1" || $(conf_read php-ver) == "7.0" || $(conf_read php-ver) == "5.6") ]]; then
|
|
echo "${gre}Default PHP version '$(conf_read php-ver)' detected!${end}"
|
|
else
|
|
# Default PHP version
|
|
conf_write php-ver 7.2
|
|
fi
|
|
ver=$(conf_read php-ver)
|
|
|
|
# Multi-PHP
|
|
if [[ $(conf_read multi-php) == "true" && -n $1 && $1 =~ ^(5.6|7.0|7.1|7.2)$ && $(conf_read php) == "true" && $1 != $ver ]]; then
|
|
ver="$1"
|
|
echo "${gre}Multi-PHP version is enabled. PHP '$ver' will be installed!${end}"
|
|
elif [[ $(conf_read multi-php) != "true" && -n $1 ]]; then
|
|
echo "${red}Multi-PHP is not enabled! ${end}"
|
|
exit 1
|
|
elif [[ $(conf_read multi-php) == "true" && -n $1 ]]; then
|
|
echo "${red}Please, enter a valid PHP version or default PHP is not installed yet! ${end}"
|
|
exit 1
|
|
fi
|
|
|
|
pre_install
|
|
if [[ $(conf_read php) != "true" ]]; then
|
|
# Fix ondrej issue - https://github.com/oerdnj/deb.sury.org/issues/56
|
|
sudo apt-get install -y language-pack-en-base
|
|
sudo LC_ALL=C.UTF-8 add-apt-repository -y ppa:ondrej/php
|
|
fi
|
|
pre_install
|
|
sudo apt-get -y install php${ver}-common php${ver}-cli php${ver}-fpm php${ver}-curl php${ver}-gd php${ver}-imap php${ver}-readline php${ver}-recode php${ver}-mysql php${ver}-mbstring php${ver}-bcmath php${ver}-mysql php${ver}-opcache php${ver}-zip php${ver}-xml php${ver}-soap php-imagick graphviz php-pear php-msgpack
|
|
|
|
if [[ -n $ver && ($ver == "7.1" || $ver == "7.0" || $ver == "5.6") ]]; then
|
|
# mcrypt deprecated in 7.2
|
|
sudo apt-get -y install php${ver}-mcrypt
|
|
fi
|
|
if [[ -n $ver && ($ver == "7.2" || $ver == "7.1" || $ver == "7.0") ]]; then
|
|
# xdebug deprecated in 5.6
|
|
sudo apt-get -y install php-xdebug
|
|
fi
|
|
|
|
def=$(conf_read php-ver)
|
|
if [[ $(conf_read php-v${def}) != "true" ]]; then
|
|
sudo cp /etc/php/$ver/fpm/php.ini /opt/webinoly/templates/source/
|
|
sudo cp /etc/php/$ver/fpm/pool.d/www.conf /opt/webinoly/templates/source/
|
|
fi
|
|
|
|
conf_write php true
|
|
conf_write php-v$ver true
|
|
echo "${gre}PHP has been installed successfully! ${end}"
|
|
api-events_update ip2
|
|
}
|
|
|
|
|
|
mysql_install() {
|
|
api-events_update im1
|
|
pre_install
|
|
[[ $(conf_read mysql-client) != "true" ]] && mysql_client_install
|
|
|
|
# debconf-utils for unattended scripts
|
|
# debconf-get-selections | grep phpmyadmin <<-- list conf variables
|
|
sudo apt-get -y install debconf-utils
|
|
|
|
# Generate mysql user passwords
|
|
local AUTOGENPASS_ROOT=`pwgen -s -1`
|
|
local AUTOGENPASS_ADMIN=`pwgen -s -1`
|
|
local enc_pass_root=$( echo $AUTOGENPASS_ROOT | openssl enc -a -salt )
|
|
local enc_pass_admin=$( echo $AUTOGENPASS_ADMIN | openssl enc -a -salt )
|
|
conf_write mysql-root $enc_pass_root
|
|
conf_write mysql-admin $enc_pass_admin
|
|
|
|
# MariaDB Installation
|
|
echo "mariadb-server-10.2 mysql-server/root_password password $AUTOGENPASS_ROOT" | debconf-set-selections
|
|
echo "mariadb-server-10.2 mysql-server/root_password_again password $AUTOGENPASS_ROOT" | debconf-set-selections
|
|
sudo apt-get -y install mariadb-server
|
|
|
|
#Instead of mysql_secure_installation we do this: (same but manually, because not acept unattended)
|
|
#ALTER USER 'root'@'localhost' IDENTIFIED BY '${AUTOGENPASS_ROOT}'; <<<--- For MySQL 5.7.6 and newer as well as MariaDB 10.1.20 and newer instead of UPDATE
|
|
sudo mysql --user=root -p$AUTOGENPASS_ROOT <<_EOF_
|
|
UPDATE mysql.user SET authentication_string = PASSWORD('${AUTOGENPASS_ROOT}') WHERE User = 'root' AND Host = 'localhost';
|
|
DELETE FROM mysql.user WHERE User='';
|
|
DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1', '::1');
|
|
DROP DATABASE IF EXISTS test;
|
|
DELETE FROM mysql.db WHERE Db='test' OR Db='test\\_%';
|
|
CREATE USER IF NOT EXISTS 'admin'@'localhost' IDENTIFIED BY '${AUTOGENPASS_ADMIN}';
|
|
GRANT ALL PRIVILEGES ON *.* TO 'admin'@'localhost' WITH GRANT OPTION;
|
|
FLUSH PRIVILEGES;
|
|
_EOF_
|
|
|
|
conf_write mysql true
|
|
echo "${gre}MySQL has been installed successfully! ${end}"
|
|
api-events_update im4
|
|
}
|
|
|
|
|
|
#NGINX OPTIM
|
|
nginx_optim() {
|
|
api-events_update in3
|
|
sudo cp -R /opt/webinoly/templates/nginx/common /etc/nginx/common
|
|
sudo cp -R /opt/webinoly/templates/nginx/conf.d/* /etc/nginx/conf.d/
|
|
|
|
sudo cat /opt/webinoly/templates/nginx/nginx.conf > /etc/nginx/nginx.conf
|
|
|
|
sudo sed -i '/REQUEST_SCHEME/c \fastcgi_param SCRIPT_FILENAME $request_filename;' /etc/nginx/fastcgi_params
|
|
sudo sed -i '/REDIRECT_STATUS/a \fastcgi_param HTTP_PROXY "";' /etc/nginx/fastcgi_params
|
|
|
|
# Create Direct Access for easy navigation
|
|
[ -L $HOME/sites-available ] || ln -s /etc/nginx/sites-available $HOME
|
|
[ -L $HOME/www ] || ln -s /var/www $HOME
|
|
|
|
# www-data sftp default uploads permissions 755 and 644, instead of 775 and 664.
|
|
sudo sed -i '/USERGROUPS_ENAB/c \USERGROUPS_ENAB no' /etc/login.defs
|
|
|
|
if [[ ! -a /etc/ssl/dhparam.pem ]]; then
|
|
sudo openssl dhparam -out /etc/ssl/dhparam.pem 2048
|
|
sudo chmod 600 /etc/ssl/dhparam.pem
|
|
fi
|
|
|
|
linux_optim > /dev/null 2>&1 &
|
|
conf_write server-version $(svr_version)
|
|
conf_write nginx-optim true
|
|
api-events_update in8
|
|
}
|
|
|
|
|
|
|
|
# PHP OPTIM
|
|
php_optim() {
|
|
api-events_update ip3
|
|
[[ -n $1 ]] && ver="$1" || ver=$(conf_read php-ver)
|
|
|
|
if [[ -n $(conf_read max-mb-uploads) && $(conf_read max-mb-uploads) =~ ^[0-9]+$ ]]; then
|
|
local maxuploads=$(conf_read max-mb-uploads)
|
|
else
|
|
local maxuploads="50"
|
|
fi
|
|
|
|
sudo sed -i '/memory_limit =/c\memory_limit = 128M' /etc/php/$ver/fpm/php.ini
|
|
sudo sed -i '/max_execution_time =/c\max_execution_time = 300' /etc/php/$ver/fpm/php.ini
|
|
sudo sed -i '/expose_php =/c\expose_php = Off' /etc/php/$ver/fpm/php.ini
|
|
sudo sed -i "/upload_max_filesize =/c\upload_max_filesize = ${maxuploads}M" /etc/php/$ver/fpm/php.ini
|
|
sudo sed -i "/post_max_size =/c\post_max_size = ${maxuploads}M" /etc/php/$ver/fpm/php.ini
|
|
sudo sed -i '/max_file_uploads =/c\max_file_uploads = 20' /etc/php/$ver/fpm/php.ini
|
|
sudo sed -i '/session.cookie_httponly =/c\session.cookie_httponly = 1' /etc/php/$ver/fpm/php.ini
|
|
set_timezone php
|
|
|
|
sudo mkdir -p /var/log/php/$ver
|
|
sudo touch /var/log/php/$ver/fpm.log
|
|
sudo sed -i "/error_log =/c\error_log = /var/log/php/$ver/fpm.log" /etc/php/$ver/fpm/php-fpm.conf
|
|
sudo sed -i '/log_level =/c\log_level = notice' /etc/php/$ver/fpm/php-fpm.conf
|
|
|
|
sudo sed -i '/pm =/c\pm = ondemand' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/request_terminate_timeout =/c\request_terminate_timeout = 300' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/pm.max_spare_servers =/c\pm.max_spare_servers = 35' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/pm.min_spare_servers =/c\pm.min_spare_servers = 10' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/pm.start_servers =/c\pm.start_servers = 15' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/pm.max_children =/c\pm.max_children = 100' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/pm.max_requests =/c\pm.max_requests = 500' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/pm.status_path =/c\pm.status_path = /status' /etc/php/$ver/fpm/pool.d/www.conf
|
|
sudo sed -i '/ping.path =/c\ping.path = /ping' /etc/php/$ver/fpm/pool.d/www.conf
|
|
|
|
if [[ $(conf_read multi-php) == "true" ]]; then
|
|
[[ $ver == 7.2 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9000' /etc/php/$ver/fpm/pool.d/www.conf
|
|
[[ $ver == 7.1 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9002' /etc/php/$ver/fpm/pool.d/www.conf
|
|
[[ $ver == 7.0 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9004' /etc/php/$ver/fpm/pool.d/www.conf
|
|
[[ $ver == 5.6 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9006' /etc/php/$ver/fpm/pool.d/www.conf
|
|
else
|
|
sudo sed -i '/listen = /c\listen = 127.0.0.1:9000' /etc/php/$ver/fpm/pool.d/www.conf
|
|
fi
|
|
|
|
sudo touch /var/log/php/$ver/slow.log
|
|
sudo cp /etc/php/$ver/fpm/pool.d/www.conf /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo sed -i '/\[www\]/c\[debug]' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo sed -i '/rlimit_core =/c\rlimit_core = unlimited' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo sed -i "/slowlog =/c\slowlog = /var/log/php/$ver/slow.log" /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo sed -i '/request_slowlog_timeout =/c\request_slowlog_timeout = 10s' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
|
|
if [[ $(conf_read multi-php) == "true" ]]; then
|
|
[[ $ver == 7.2 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9001' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
[[ $ver == 7.1 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9003' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
[[ $ver == 7.0 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9005' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
[[ $ver == 5.6 ]] && sudo sed -i '/listen = /c\listen = 127.0.0.1:9007' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
else
|
|
sudo sed -i '/listen = /c\listen = 127.0.0.1:9001' /etc/php/$ver/fpm/pool.d/debug.conf
|
|
fi
|
|
|
|
if [[ -n $ver && ($ver == "7.2" || $ver == "7.1" || $ver == "7.0") ]]; then
|
|
# xdebug deprecated in 5.6
|
|
sudo echo 'php_admin_flag[xdebug.profiler_enable] = off' >> /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo echo 'php_admin_flag[xdebug.profiler_enable_trigger] = on' >> /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo echo 'php_admin_value[xdebug.profiler_output_name] = cachegrind.out.%p-%H-%R' >> /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo echo 'php_admin_value[xdebug.profiler_output_dir] = /tmp/' >> /etc/php/$ver/fpm/pool.d/debug.conf
|
|
sudo sed -i '/zend_extension=/c\;zend_extension=xdebug.so' /etc/php/$ver/mods-available/xdebug.ini
|
|
fi
|
|
|
|
conf_write php-optim true
|
|
sudo service php*-fpm reload
|
|
api-events_update ip4
|
|
}
|
|
|
|
|
|
nginx_tool_site() {
|
|
# Port 22222 tools site
|
|
sudo site $(conf_read tools-port) -php
|
|
sudo cp /opt/webinoly/templates/nginx/22222 /etc/nginx/sites-available/$(conf_read tools-port)
|
|
sudo sed -i "s/22222/$(conf_read tools-port)/g" /etc/nginx/sites-available/$(conf_read tools-port)
|
|
sudo service nginx reload
|
|
}
|
|
|
|
|
|
nginx_tool() {
|
|
api-events_update in9
|
|
[[ -z $(conf_read tools-port) ]] && tools_port 22222
|
|
[[ $(conf_read php) == "true" ]] && nginx_tool_site
|
|
# in case php was installed before nginx
|
|
[[ $(conf_read php-tool) == "true" && ! -a /var/www/$(conf_read tools-port)/htdocs/php/index.php ]] && php_tool_site
|
|
|
|
# Install LetsEncrypt
|
|
echo | sudo add-apt-repository ppa:certbot/certbot
|
|
pre_install
|
|
sudo apt-get -y install certbot
|
|
|
|
# Instalar Duply & Duplicity
|
|
sudo apt-get -y install python-boto duplicity duply
|
|
|
|
conf_write nginx-tool true
|
|
api-events_update in10
|
|
}
|
|
|
|
|
|
php_tool_site() {
|
|
api-events_update ip6
|
|
# Status pages
|
|
sudo mkdir -p /var/www/$(conf_read tools-port)/htdocs/fpm/status
|
|
sudo touch /var/www/$(conf_read tools-port)/htdocs/fpm/status/php
|
|
sudo touch /var/www/$(conf_read tools-port)/htdocs/fpm/status/debug
|
|
|
|
#PHP info site
|
|
sudo mkdir -p /var/www/$(conf_read tools-port)/htdocs/php
|
|
sudo touch /var/www/$(conf_read tools-port)/htdocs/php/index.php
|
|
sudo echo '<?php phpinfo(); ?>' >> /var/www/$(conf_read tools-port)/htdocs/php/index.php
|
|
api-events_update ip7
|
|
}
|
|
|
|
|
|
php_tool() {
|
|
api-events_update ip5
|
|
# in case nginx was installed before php
|
|
if [[ $(conf_read nginx-tool) == "true" && ! -a /etc/nginx/sites-available/$(conf_read tools-port) ]]; then
|
|
nginx_tool_site
|
|
fi
|
|
if [[ $(conf_read nginx) == "true" ]]; then
|
|
php_tool_site
|
|
fi
|
|
|
|
# Redis (Object Cache)
|
|
echo | sudo add-apt-repository ppa:chris-lea/redis-server
|
|
pre_install
|
|
sudo apt-get -y install redis-server php-redis
|
|
|
|
# Memcached (Object Cache)
|
|
sudo apt-get -y install php-memcached php-memcache memcached
|
|
|
|
# Postfix mail
|
|
echo "postfix postfix/main_mailer_type select Internet Site" | debconf-set-selections
|
|
echo "postfix postfix/mailname string $hostname" | debconf-set-selections
|
|
sudo apt-get -y install postfix
|
|
|
|
sudo service php*-fpm reload
|
|
conf_write php-tool true
|
|
api-events_update ip8
|
|
}
|
|
|
|
|
|
mysql_tool() {
|
|
api-events_update im5
|
|
sudo mkdir /var/www/$(conf_read tools-port)/htdocs/pma
|
|
sudo wget --timeout=15 -qrO /var/www/$(conf_read tools-port)/htdocs/pma.tar.xz https://www.phpmyadmin.net/downloads/phpMyAdmin-latest-all-languages.tar.xz
|
|
sudo tar -xf /var/www/$(conf_read tools-port)/htdocs/pma.tar.xz -C /var/www/$(conf_read tools-port)/htdocs/pma
|
|
sudo mv /var/www/$(conf_read tools-port)/htdocs/pma/phpMyAdmin-*-all-languages/* /var/www/$(conf_read tools-port)/htdocs/pma/
|
|
sudo rm -rf /var/www/$(conf_read tools-port)/htdocs/pma/phpMyAdmin-*-all-languages
|
|
sudo rm -rf /var/www/$(conf_read tools-port)/htdocs/pma/test
|
|
sudo rm -rf /var/www/$(conf_read tools-port)/htdocs/pma/setup
|
|
sudo rm /var/www/$(conf_read tools-port)/htdocs/pma.tar.xz
|
|
|
|
sudo cp /var/www/$(conf_read tools-port)/htdocs/pma/config.sample.inc.php /var/www/$(conf_read tools-port)/htdocs/pma/config.inc.php
|
|
sudo sed -i "/blowfish_secret/c \$cfg['blowfish_secret'] = '$(pwgen -s -1 32)';" /var/www/$(conf_read tools-port)/htdocs/pma/config.inc.php
|
|
sudo chown -R www-data:www-data /var/www/$(conf_read tools-port)/htdocs/pma
|
|
|
|
conf_write mysql-tool true
|
|
echo "${gre}PhpMyAdmin has been installed successfully! ${end}"
|
|
api-events_update im6
|
|
}
|
|
|
|
|
|
swap_delete() {
|
|
local swapkb=$(grep SwapTotal /proc/meminfo | cut -f 2 -d ':' | tr -d ' ' | cut -f 1 -d 'k')
|
|
if [[ -n $swapkb && $swapkb =~ ^[0-9]+$ && $swapkb -gt 0 && $(conf_read swap-owner) == "webinoly" ]]; then
|
|
api-events_update pn9
|
|
sudo swapoff -a -v > /dev/null
|
|
sudo rm /swapfile
|
|
sudo sed -i '/\/swapfile/d' /etc/fstab
|
|
sudo sed -i '/vm.swappiness/d' /etc/sysctl.conf
|
|
conf_delete swap-owner
|
|
api-events_update pn10
|
|
fi
|
|
}
|
|
|
|
|
|
swap_create() {
|
|
local swapkb=$(grep SwapTotal /proc/meminfo | cut -f 2 -d ':' | tr -d ' ' | cut -f 1 -d 'k')
|
|
local swap=$(($swapkb/1048000))
|
|
local ramkb=$(grep MemTotal /proc/meminfo | cut -f 2 -d ':' | tr -d ' ' | cut -f 1 -d 'k')
|
|
local ram=$(($ramkb/1048000))
|
|
|
|
# Delete if new custom swap is found.
|
|
if [[ -n $(conf_read swap-mem) && $(conf_read swap-mem) =~ ^[0-9]+$ && $(conf_read swap-mem) != $swapkb ]]; then
|
|
swap_delete
|
|
swapkb=$(grep SwapTotal /proc/meminfo | cut -f 2 -d ':' | tr -d ' ' | cut -f 1 -d 'k')
|
|
fi
|
|
|
|
# https://help.ubuntu.com/community/SwapFaq
|
|
if [[ -z $swapkb || $swapkb == "0" ]]; then
|
|
api-events_update in5
|
|
if [[ -n $(conf_read swap-mem) && $(conf_read swap-mem) =~ ^[0-9]+$ ]]; then
|
|
local newswap=$(conf_read swap-mem)
|
|
elif [[ $ram -le 2 ]]; then
|
|
local newswap="1"
|
|
elif [[ $ram -le 6 ]]; then
|
|
local newswap="2"
|
|
elif [[ $ram -le 12 ]]; then
|
|
local newswap="3"
|
|
elif [[ $ram -le 16 ]]; then
|
|
local newswap="4"
|
|
elif [[ $ram -le 24 ]]; then
|
|
local newswap="5"
|
|
elif [[ $ram -le 32 ]]; then
|
|
local newswap="6"
|
|
elif [[ $ram -le 64 ]]; then
|
|
local newswap="8"
|
|
elif [[ $ram -le 128 ]]; then
|
|
local newswap="11"
|
|
elif [[ $ram -gt 128 ]]; then
|
|
local newswap="15"
|
|
else
|
|
local newswap="0"
|
|
fi
|
|
|
|
if [[ -z $newswap || $newswap == 0 ]]; then
|
|
echo "${red} [ERROR] Webinoly could not create a new Swap Partition! ${end}"
|
|
else
|
|
# Create SWAP Partition
|
|
sudo dd if=/dev/zero of=/swapfile bs=${newswap}M count=1024
|
|
|
|
sudo chown root:root /swapfile
|
|
sudo chmod 0600 /swapfile
|
|
|
|
sudo mkswap /swapfile
|
|
sudo swapon /swapfile
|
|
|
|
sudo sed -i "/LABEL.*/a \/swapfile none swap sw 0 0" /etc/fstab
|
|
|
|
echo 10 | sudo tee /proc/sys/vm/swappiness
|
|
echo vm.swappiness = 10 | sudo tee -a /etc/sysctl.conf
|
|
|
|
# Swap created by Webinoly - so we should remove it in uninstall
|
|
conf_write swap-owner webinoly
|
|
|
|
echo "${gre} A new SWAP Partion (${newswap}Gb) has been created! ${end}"
|
|
fi
|
|
api-events_update in6
|
|
else
|
|
if [[ $(conf_read swap-owner) != "webinoly" ]]; then
|
|
conf_write swap-owner system
|
|
fi
|
|
echo "${gre} SWAP Memory (${swap}Gb) detected!${end}"
|
|
fi
|
|
}
|