update comment
This commit is contained in:
parent
aa595da5ea
commit
14c72e5ee1
|
|
@ -1,4 +1,4 @@
|
||||||
#! /bin/bash
|
#!/usr/bin/env bash
|
||||||
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
|
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
|
||||||
export PATH
|
export PATH
|
||||||
#=================================================================#
|
#=================================================================#
|
||||||
|
|
@ -15,12 +15,12 @@ echo "#############################################################"
|
||||||
echo "# One click Install Shadowsocks-go server #"
|
echo "# One click Install Shadowsocks-go server #"
|
||||||
echo "# Intro: https://teddysun.com/392.html #"
|
echo "# Intro: https://teddysun.com/392.html #"
|
||||||
echo "# Author: Teddysun <i@teddysun.com> #"
|
echo "# Author: Teddysun <i@teddysun.com> #"
|
||||||
echo "# Thanks: @cyfdecyf <https://twitter.com/cyfdecyf> #"
|
echo "# Github: https://github.com/shadowsocks/shadowsocks-go #"
|
||||||
echo "#############################################################"
|
echo "#############################################################"
|
||||||
echo
|
echo
|
||||||
|
|
||||||
# Make sure only root can run our script
|
# Make sure only root can run our script
|
||||||
function rootness(){
|
rootness(){
|
||||||
if [[ $EUID -ne 0 ]]; then
|
if [[ $EUID -ne 0 ]]; then
|
||||||
echo "Error:This script must be run as root!" 1>&2
|
echo "Error:This script must be run as root!" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|
@ -28,7 +28,7 @@ function rootness(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# Check OS
|
# Check OS
|
||||||
function checkos(){
|
checkos(){
|
||||||
if [ -f /etc/redhat-release ];then
|
if [ -f /etc/redhat-release ];then
|
||||||
OS=CentOS
|
OS=CentOS
|
||||||
elif [ ! -z "`cat /etc/issue | grep bian`" ];then
|
elif [ ! -z "`cat /etc/issue | grep bian`" ];then
|
||||||
|
|
@ -42,7 +42,7 @@ function checkos(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# Get version
|
# Get version
|
||||||
function getversion(){
|
getversion(){
|
||||||
if [[ -s /etc/redhat-release ]];then
|
if [[ -s /etc/redhat-release ]];then
|
||||||
grep -oE "[0-9.]+" /etc/redhat-release
|
grep -oE "[0-9.]+" /etc/redhat-release
|
||||||
else
|
else
|
||||||
|
|
@ -51,7 +51,7 @@ function getversion(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# CentOS version
|
# CentOS version
|
||||||
function centosversion(){
|
centosversion(){
|
||||||
local code=$1
|
local code=$1
|
||||||
local version="`getversion`"
|
local version="`getversion`"
|
||||||
local main_ver=${version%%.*}
|
local main_ver=${version%%.*}
|
||||||
|
|
@ -63,7 +63,7 @@ function centosversion(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# is 64bit or not
|
# is 64bit or not
|
||||||
function is_64bit(){
|
is_64bit(){
|
||||||
if [ `getconf WORD_BIT` = '32' ] && [ `getconf LONG_BIT` = '64' ] ; then
|
if [ `getconf WORD_BIT` = '32' ] && [ `getconf LONG_BIT` = '64' ] ; then
|
||||||
return 0
|
return 0
|
||||||
else
|
else
|
||||||
|
|
@ -72,15 +72,22 @@ function is_64bit(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# Disable selinux
|
# Disable selinux
|
||||||
function disable_selinux(){
|
disable_selinux(){
|
||||||
if [ -s /etc/selinux/config ] && grep 'SELINUX=enforcing' /etc/selinux/config; then
|
if [ -s /etc/selinux/config ] && grep 'SELINUX=enforcing' /etc/selinux/config; then
|
||||||
sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
|
sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
|
||||||
setenforce 0
|
setenforce 0
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get_ip(){
|
||||||
|
local IP=$( ip addr | egrep -o '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}' | egrep -v "^192\.168|^172\.1[6-9]\.|^172\.2[0-9]\.|^172\.3[0-2]\.|^10\.|^127\.|^255\.|^0\." | head -n 1 )
|
||||||
|
[ -z ${IP} ] && IP=$( wget -qO- -t1 -T2 ipv4.icanhazip.com )
|
||||||
|
[ -z ${IP} ] && IP=$( wget -qO- -t1 -T2 ipinfo.io/ip )
|
||||||
|
[ ! -z ${IP} ] && echo ${IP} || echo
|
||||||
|
}
|
||||||
|
|
||||||
# Pre-installation settings
|
# Pre-installation settings
|
||||||
function pre_install(){
|
pre_install(){
|
||||||
# Set shadowsocks-go config password
|
# Set shadowsocks-go config password
|
||||||
echo "Please input password for shadowsocks-go:"
|
echo "Please input password for shadowsocks-go:"
|
||||||
read -p "(Default password: teddysun.com):" shadowsockspwd
|
read -p "(Default password: teddysun.com):" shadowsockspwd
|
||||||
|
|
@ -95,10 +102,10 @@ function pre_install(){
|
||||||
do
|
do
|
||||||
echo -e "Please input port for shadowsocks-go [1-65535]:"
|
echo -e "Please input port for shadowsocks-go [1-65535]:"
|
||||||
read -p "(Default port: 8989):" shadowsocksport
|
read -p "(Default port: 8989):" shadowsocksport
|
||||||
[ -z "$shadowsocksport" ] && shadowsocksport="8989"
|
[ -z "${shadowsocksport}" ] && shadowsocksport="8989"
|
||||||
expr $shadowsocksport + 0 &>/dev/null
|
expr ${shadowsocksport} + 0 &>/dev/null
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
if [ $shadowsocksport -ge 1 ] && [ $shadowsocksport -le 65535 ]; then
|
if [ ${shadowsocksport} -ge 1 ] && [ ${shadowsocksport} -le 65535 ]; then
|
||||||
echo
|
echo
|
||||||
echo "---------------------------"
|
echo "---------------------------"
|
||||||
echo "port = $shadowsocksport"
|
echo "port = $shadowsocksport"
|
||||||
|
|
@ -133,21 +140,17 @@ function pre_install(){
|
||||||
fi
|
fi
|
||||||
# Get IP address
|
# Get IP address
|
||||||
echo "Getting Public IP address, Please wait a moment..."
|
echo "Getting Public IP address, Please wait a moment..."
|
||||||
IP=$(curl -s -4 icanhazip.com)
|
echo -e "Your main public IP is\t\033[32m $(get_ip) \033[0m"
|
||||||
if [[ "$IP" = "" ]]; then
|
|
||||||
IP=$(curl -s -4 ipinfo.io/ip)
|
|
||||||
fi
|
|
||||||
echo -e "Your main public IP is\t\033[32m$IP\033[0m"
|
|
||||||
echo
|
echo
|
||||||
#Current folder
|
#Current folder
|
||||||
cur_dir=`pwd`
|
cur_dir=`pwd`
|
||||||
}
|
}
|
||||||
|
|
||||||
# Download shadowsocks-go
|
# Download shadowsocks-go
|
||||||
function download_files(){
|
download_files(){
|
||||||
cd $cur_dir
|
cd ${cur_dir}
|
||||||
if is_64bit; then
|
if is_64bit; then
|
||||||
if ! wget -c http://lamp.teddysun.com/shadowsocks/shadowsocks-server-linux64-1.1.5.gz;then
|
if ! wget -c http://dl.teddysun.com/shadowsocks/shadowsocks-server-linux64-1.1.5.gz;then
|
||||||
echo "Failed to download shadowsocks-server-linux64-1.1.5.gz"
|
echo "Failed to download shadowsocks-server-linux64-1.1.5.gz"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
@ -160,7 +163,7 @@ function download_files(){
|
||||||
fi
|
fi
|
||||||
mv -f shadowsocks-server-linux64-1.1.5 /usr/bin/shadowsocks-server
|
mv -f shadowsocks-server-linux64-1.1.5 /usr/bin/shadowsocks-server
|
||||||
else
|
else
|
||||||
if ! wget -c http://lamp.teddysun.com/shadowsocks/shadowsocks-server-linux32-1.1.5.gz;then
|
if ! wget -c http://dl.teddysun.com/shadowsocks/shadowsocks-server-linux32-1.1.5.gz;then
|
||||||
echo "Failed to download shadowsocks-server-linux32-1.1.5.gz"
|
echo "Failed to download shadowsocks-server-linux32-1.1.5.gz"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
@ -189,7 +192,7 @@ function download_files(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# Config shadowsocks
|
# Config shadowsocks
|
||||||
function config_shadowsocks(){
|
config_shadowsocks(){
|
||||||
if [ ! -d /etc/shadowsocks ];then
|
if [ ! -d /etc/shadowsocks ];then
|
||||||
mkdir /etc/shadowsocks
|
mkdir /etc/shadowsocks
|
||||||
fi
|
fi
|
||||||
|
|
@ -206,7 +209,7 @@ EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
# firewall set
|
# firewall set
|
||||||
function firewall_set(){
|
firewall_set(){
|
||||||
echo "firewall set start..."
|
echo "firewall set start..."
|
||||||
if centosversion 6; then
|
if centosversion 6; then
|
||||||
/etc/init.d/iptables status > /dev/null 2>&1
|
/etc/init.d/iptables status > /dev/null 2>&1
|
||||||
|
|
@ -245,12 +248,12 @@ function firewall_set(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# Install
|
# Install
|
||||||
function install_go(){
|
install_go(){
|
||||||
# Install shadowsocks-go
|
# Install shadowsocks-go
|
||||||
if [ -s /usr/bin/shadowsocks-server ]; then
|
if [ -s /usr/bin/shadowsocks-server ]; then
|
||||||
echo "shadowsocks-go install success!"
|
echo "shadowsocks-go install success!"
|
||||||
chmod +x /usr/bin/shadowsocks-server
|
chmod +x /usr/bin/shadowsocks-server
|
||||||
mv $cur_dir/shadowsocks-go /etc/init.d/shadowsocks
|
mv ${cur_dir}/shadowsocks-go /etc/init.d/shadowsocks
|
||||||
chmod +x /etc/init.d/shadowsocks
|
chmod +x /etc/init.d/shadowsocks
|
||||||
# Add run on system start up
|
# Add run on system start up
|
||||||
if [ "$OS" == 'CentOS' ]; then
|
if [ "$OS" == 'CentOS' ]; then
|
||||||
|
|
@ -275,7 +278,7 @@ function install_go(){
|
||||||
clear
|
clear
|
||||||
echo
|
echo
|
||||||
echo "Congratulations, shadowsocks-go install completed!"
|
echo "Congratulations, shadowsocks-go install completed!"
|
||||||
echo -e "Your Server IP: \033[41;37m ${IP} \033[0m"
|
echo -e "Your Server IP: \033[41;37m $(get_ip) \033[0m"
|
||||||
echo -e "Your Server Port: \033[41;37m ${shadowsocksport} \033[0m"
|
echo -e "Your Server Port: \033[41;37m ${shadowsocksport} \033[0m"
|
||||||
echo -e "Your Password: \033[41;37m ${shadowsockspwd} \033[0m"
|
echo -e "Your Password: \033[41;37m ${shadowsockspwd} \033[0m"
|
||||||
echo -e "Your Local Port: \033[41;37m 1080 \033[0m"
|
echo -e "Your Local Port: \033[41;37m 1080 \033[0m"
|
||||||
|
|
@ -288,11 +291,11 @@ function install_go(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# Uninstall Shadowsocks-go
|
# Uninstall Shadowsocks-go
|
||||||
function uninstall_shadowsocks_go(){
|
uninstall_shadowsocks_go(){
|
||||||
printf "Are you sure uninstall shadowsocks-go? (y/n) "
|
printf "Are you sure uninstall shadowsocks-go? (y/n) "
|
||||||
printf "\n"
|
printf "\n"
|
||||||
read -p "(Default: n):" answer
|
read -p "(Default: n):" answer
|
||||||
if [ -z $answer ]; then
|
if [ -z ${answer} ]; then
|
||||||
answer="n"
|
answer="n"
|
||||||
fi
|
fi
|
||||||
if [ "$answer" = "y" ]; then
|
if [ "$answer" = "y" ]; then
|
||||||
|
|
@ -318,7 +321,7 @@ function uninstall_shadowsocks_go(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# Install Shadowsocks-go
|
# Install Shadowsocks-go
|
||||||
function install_shadowsocks_go(){
|
install_shadowsocks_go(){
|
||||||
checkos
|
checkos
|
||||||
rootness
|
rootness
|
||||||
disable_selinux
|
disable_selinux
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user