shadowsocks是一套技術(shù)和相關(guān)工具的總稱锨用,常備簡(jiǎn)稱為ss咬展,可以簡(jiǎn)單總結(jié)為:一套基于Sock5代理方式的網(wǎng)絡(luò)加密傳輸數(shù)據(jù)包的技術(shù) = 用Socks5 技術(shù)加密的技術(shù)泽裳。
Sock技術(shù)簡(jiǎn)介
采用sock協(xié)議的代理服務(wù)器就是 Socks 服務(wù)器,是一種通用的代理服務(wù)器破婆。
Socks代理與應(yīng)用層代理涮总、HTTP層代理不通,Socks代理只是簡(jiǎn)單的傳遞數(shù)據(jù)包祷舀,而不必關(guān)心是何種協(xié)議(比如FTP妹卿、HTTP和NNTP請(qǐng)求)。所以蔑鹦,Socks代理比其他應(yīng)用層代理要快的多夺克。
Sock5代理服務(wù)器則是把你的網(wǎng)絡(luò)數(shù)據(jù)請(qǐng)求通過(guò)一條連接你和代理服務(wù)器之間的通道,由服務(wù)器轉(zhuǎn)發(fā)到目的地嚎朽。你沒(méi)有加入任何新的網(wǎng)絡(luò)铺纽,只是http/socks數(shù)據(jù)經(jīng)過(guò)代理服務(wù)器的轉(zhuǎn)發(fā)送出,并從代理服務(wù)器接收回應(yīng)哟忍。你與代理服務(wù)器通信過(guò)程不會(huì)被額外處理狡门,如果你用https,那本身就是加密的锅很。
搭建:
1其馏、參考安裝教程:http://totoro.site/index.php/archives/54? ,按照該教程安裝時(shí)爆安,出現(xiàn)錯(cuò)誤叛复,根據(jù)錯(cuò)誤提示,發(fā)現(xiàn)是 解壓 mbedtls-2.13.0-gpl.tgz 時(shí)格式不對(duì)造成的扔仓,經(jīng)過(guò)排查褐奥,該文件(mbedtls-2.13.0-gpl.tgz)不是一個(gè)壓縮包,是一個(gè)ASCII文件翘簇,更改安裝腳本中 mbedtls-2.13.0-gpl.tgz 的下載地址: https://down.24kplus.com/linux/mbedtls/mbedtls-2.16.3-gpl.tgz撬码,然后重新執(zhí)行腳本,安裝完成版保。
2呜笑、安裝 shadowsocks-libev.sh (網(wǎng)絡(luò)上該腳本中一個(gè)網(wǎng)址不存在夫否,已修改);添加執(zhí)行權(quán)限后 執(zhí)行便可: ./shadowsocks-libev.sh
3叫胁、增加用戶:useradd ss3
4慷吊、添加子接口:ifconfig eth0:0 2.2.2.2/24 或 ip addr add 2.2.2.2/24 dev eth0 label eth0:0 清除網(wǎng)卡子接口,刪除ip別名 ifconfig eth0:1 down? 或 ip addr del 2.2.2.2/24 dev eth0 label eth0:0? 曹抬;
若是想永久生效溉瓶,創(chuàng)建:/etc/sysconfig/network-scripts/ifcfg-eth0:0 添加:(文件中僅有下面四行便可)
DEVICE=eth0:0
IPADDR=2.2.2.2
PREFIX=24
ONPARENT=yes
注:使用命令添加后立刻生效,增加配置文件是在系統(tǒng)重啟后生效谤民,所以需要使用命令添加并且增加配置文件才可以立即增加且永久生效堰酿。
5、使用新建的用戶運(yùn)行:ss-server -a ss3 -c /home/ss3/ss3.json -u &
6张足、防火墻放行相應(yīng)端口(tcp放行就可以了触创,但是網(wǎng)上教程都放行了udp)
iptables -I INPUT -p tcp --dport 14278 -j ACCEPT
或:firewall-cmd --permanent --zone=public --add-port=11126/tcp
7、查看是否成功啟動(dòng)并監(jiān)聽(tīng)相應(yīng)端口
ps -aux | grep ss-server
netstat -anlp | grep ss-server
8为牍、若想中斷某個(gè)ss-server進(jìn)程哼绑,先通過(guò) ps -aux 找到pid,之后通過(guò) kill [pid] 強(qiáng)制中斷碉咆。
附錄:
可以將一下代碼復(fù)制到Linux的一個(gè)腳本中抖韩,直接運(yùn)行,便可安裝好shadowsocks-libev
#!/usr/bin/env bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
#===================================================================#
#? System Required:? CentOS 6 or 7? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #
#? Description: Install Shadowsocks-libev server for CentOS 6 or 7 #
#? Author: Teddysun <i@teddysun.com>? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #
#? Thanks: @madeye <https://github.com/madeye>? ? ? ? ? ? ? ? ? ? #
#? Intro:? https://teddysun.com/357.html? ? ? ? ? ? ? ? ? ? ? ? ? #
#===================================================================#
# Current folder
cur_dir=`pwd`
libsodium_file="libsodium-1.0.16"
libsodium_url="https://github.com/jedisct1/libsodium/releases/download/1.0.16/libsodium-1.0.16.tar.gz"
mbedtls_file="mbedtls-2.16.3"
mbedtls_url="https://down.24kplus.com/linux/mbedtls/mbedtls-2.16.3-gpl.tgz"
# Stream Ciphers
ciphers=(
aes-256-gcm
aes-192-gcm
aes-128-gcm
aes-256-ctr
aes-192-ctr
aes-128-ctr
aes-256-cfb
aes-192-cfb
aes-128-cfb
camellia-128-cfb
camellia-192-cfb
camellia-256-cfb
xchacha20-ietf-poly1305
chacha20-ietf-poly1305
chacha20-ietf
chacha20
salsa20
rc4-md5
)
# Color
red='\033[0;31m'
green='\033[0;32m'
yellow='\033[0;33m'
plain='\033[0m'
# Make sure only root can run our script
[[ $EUID -ne 0 ]] && echo -e "[${red}Error${plain}] This script must be run as root!" && exit 1
# Disable selinux
disable_selinux(){
? ? if [ -s /etc/selinux/config ] && grep 'SELINUX=enforcing' /etc/selinux/config; then
? ? ? ? sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
? ? ? ? setenforce 0
? ? 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
}
get_ipv6(){
? ? local ipv6=$(wget -qO- -t1 -T2 ipv6.icanhazip.com)
? ? if [ -z ${ipv6} ]; then
? ? ? ? return 1
? ? else
? ? ? ? return 0
? ? fi
}
get_char(){
? ? SAVEDSTTY=`stty -g`
? ? stty -echo
? ? stty cbreak
? ? dd if=/dev/tty bs=1 count=1 2> /dev/null
? ? stty -raw
? ? stty echo
? ? stty $SAVEDSTTY
}
get_latest_version(){
? ? ver=$(wget --no-check-certificate -qO- https://api.github.com/repos/shadowsocks/shadowsocks-libev/releases/latest | grep 'tag_name' | cut -d\" -f4)
? ? [ -z ${ver} ] && echo "Error: Get shadowsocks-libev latest version failed" && exit 1
? ? shadowsocks_libev_ver="shadowsocks-libev-$(echo ${ver} | sed -e 's/^[a-zA-Z]//g')"
? ? download_link="https://github.com/shadowsocks/shadowsocks-libev/releases/download/${ver}/${shadowsocks_libev_ver}.tar.gz"
? ? init_script_link="https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/shadowsocks-libev"
}
check_installed(){
? ? if [ "$(command -v "$1")" ]; then
? ? ? ? return 0
? ? else
? ? ? ? return 1
? ? fi
}
check_version(){
? ? check_installed "ss-server"
? ? if [ $? -eq 0 ]; then
? ? ? ? installed_ver=$(ss-server -h | grep shadowsocks-libev | cut -d' ' -f2)
? ? ? ? get_latest_version
? ? ? ? latest_ver=$(echo ${ver} | sed -e 's/^[a-zA-Z]//g')
? ? ? ? if [ "${latest_ver}" == "${installed_ver}" ]; then
? ? ? ? ? ? return 0
? ? ? ? else
? ? ? ? ? ? return 1
? ? ? ? fi
? ? else
? ? ? ? return 2
? ? fi
}
print_info(){
? ? clear
? ? echo "#############################################################"
? ? echo "# Install Shadowsocks-libev server for CentOS 6 or 7? ? ? ? #"
? ? echo "# Intro:? https://teddysun.com/357.html? ? ? ? ? ? ? ? ? ? #"
? ? echo "# Author: Teddysun <i@teddysun.com>? ? ? ? ? ? ? ? ? ? ? ? #"
? ? echo "# Github: https://github.com/shadowsocks/shadowsocks-libev? #"
? ? echo "#############################################################"
? ? echo
}
# Check system
check_sys(){
? ? local checkType=$1
? ? local value=$2
? ? local release=''
? ? local systemPackage=''
? ? if [[ -f /etc/redhat-release ]]; then
? ? ? ? release="centos"
? ? ? ? systemPackage="yum"
? ? elif grep -Eqi "debian|raspbian" /etc/issue; then
? ? ? ? release="debian"
? ? ? ? systemPackage="apt"
? ? elif grep -Eqi "ubuntu" /etc/issue; then
? ? ? ? release="ubuntu"
? ? ? ? systemPackage="apt"
? ? elif grep -Eqi "centos|red hat|redhat" /etc/issue; then
? ? ? ? release="centos"
? ? ? ? systemPackage="yum"
? ? elif grep -Eqi "debian|raspbian" /proc/version; then
? ? ? ? release="debian"
? ? ? ? systemPackage="apt"
? ? elif grep -Eqi "ubuntu" /proc/version; then
? ? ? ? release="ubuntu"
? ? ? ? systemPackage="apt"
? ? elif grep -Eqi "centos|red hat|redhat" /proc/version; then
? ? ? ? release="centos"
? ? ? ? systemPackage="yum"
? ? fi
? ? if [[ "${checkType}" == "sysRelease" ]]; then
? ? ? ? if [ "${value}" == "${release}" ]; then
? ? ? ? ? ? return 0
? ? ? ? else
? ? ? ? ? ? return 1
? ? ? ? fi
? ? elif [[ "${checkType}" == "packageManager" ]]; then
? ? ? ? if [ "${value}" == "${systemPackage}" ]; then
? ? ? ? ? ? return 0
? ? ? ? else
? ? ? ? ? ? return 1
? ? ? ? fi
? ? fi
}
version_gt(){
? ? test "$(echo "$@" | tr " " "\n" | sort -V | head -n 1)" != "$1"
}
check_kernel_version(){
? ? local kernel_version=$(uname -r | cut -d- -f1)
? ? if version_gt ${kernel_version} 3.7.0; then
? ? ? ? return 0
? ? else
? ? ? ? return 1
? ? fi
}
check_kernel_headers(){
? ? if check_sys packageManager yum; then
? ? ? ? if rpm -qa | grep -q headers-$(uname -r); then
? ? ? ? ? ? return 0
? ? ? ? else
? ? ? ? ? ? return 1
? ? ? ? fi
? ? elif check_sys packageManager apt; then
? ? ? ? if dpkg -s linux-headers-$(uname -r) > /dev/null 2>&1; then
? ? ? ? ? ? return 0
? ? ? ? else
? ? ? ? ? ? return 1
? ? ? ? fi
? ? fi
? ? return 1
}
# Get version
getversion(){
? ? if [[ -s /etc/redhat-release ]]; then
? ? ? ? grep -oE? "[0-9.]+" /etc/redhat-release
? ? else
? ? ? ? grep -oE? "[0-9.]+" /etc/issue
? ? fi
}
# CentOS version
centosversion(){
? ? if check_sys sysRelease centos; then
? ? ? ? local code=$1
? ? ? ? local version="$(getversion)"
? ? ? ? local main_ver=${version%%.*}
? ? ? ? if [ "$main_ver" == "$code" ]; then
? ? ? ? ? ? return 0
? ? ? ? else
? ? ? ? ? ? return 1
? ? ? ? fi
? ? else
? ? ? ? return 1
? ? fi
}
# Pre-installation settings
pre_install(){
? ? # Check OS system
? ? if check_sys sysRelease centos; then
? ? ? ? # Not support CentOS 5
? ? ? ? if centosversion 5; then
? ? ? ? ? ? echo -e "[${red}Error${plain}] Not support CentOS 5, please change to CentOS 6 or 7 and try again."
? ? ? ? ? ? exit 1
? ? ? ? fi
? ? else
? ? ? ? echo -e "[${red}Error${plain}] Your OS is not supported to run it, please change OS to CentOS and try again."
? ? ? ? exit 1
? ? fi
? ? # Check version
? ? check_version
? ? status=$?
? ? if [ ${status} -eq 0 ]; then
? ? ? ? echo -e "[${green}Info${plain}] Latest version ${green}${shadowsocks_libev_ver}${plain} has already been installed, nothing to do..."
? ? ? ? exit 0
? ? elif [ ${status} -eq 1 ]; then
? ? ? ? echo -e "Installed version: ${red}${installed_ver}${plain}"
? ? ? ? echo -e "Latest version: ${red}${latest_ver}${plain}"
? ? ? ? echo -e "[${green}Info${plain}] Upgrade shadowsocks libev to latest version..."
? ? ? ? ps -ef | grep -v grep | grep -i "ss-server" > /dev/null 2>&1
? ? ? ? if [ $? -eq 0 ]; then
? ? ? ? ? ? /etc/init.d/shadowsocks stop
? ? ? ? fi
? ? elif [ ${status} -eq 2 ]; then
? ? ? ? print_info
? ? ? ? get_latest_version
? ? ? ? echo -e "[${green}Info${plain}] Latest version: ${green}${shadowsocks_libev_ver}${plain}"
? ? ? ? echo
? ? fi
? ? # Set shadowsocks-libev config password
? ? echo "Please enter password for shadowsocks-libev:"
? ? read -p "(Default password: teddysun.com):" shadowsockspwd
? ? [ -z "${shadowsockspwd}" ] && shadowsockspwd="teddysun.com"
? ? echo
? ? echo "---------------------------"
? ? echo "password = ${shadowsockspwd}"
? ? echo "---------------------------"
? ? echo
? ? # Set shadowsocks-libev config port
? ? while true
? ? do
? ? dport=$(shuf -i 9000-19999 -n 1)
? ? echo -e "Please enter a port for shadowsocks-libev [1-65535]"
? ? read -p "(Default port: ${dport}):" shadowsocksport
? ? [ -z "$shadowsocksport" ] && shadowsocksport=${dport}
? ? expr ${shadowsocksport} + 1 &>/dev/null
? ? if [ $? -eq 0 ]; then
? ? ? ? if [ ${shadowsocksport} -ge 1 ] && [ ${shadowsocksport} -le 65535 ] && [ ${shadowsocksport:0:1} != 0 ]; then
? ? ? ? ? ? echo
? ? ? ? ? ? echo "---------------------------"
? ? ? ? ? ? echo "port = ${shadowsocksport}"
? ? ? ? ? ? echo "---------------------------"
? ? ? ? ? ? echo
? ? ? ? ? ? break
? ? ? ? fi
? ? fi
? ? echo -e "[${red}Error${plain}] Please enter a correct number [1-65535]"
? ? done
? ? # Set shadowsocks config stream ciphers
? ? while true
? ? do
? ? echo -e "Please select stream cipher for shadowsocks-libev:"
? ? for ((i=1;i<=${#ciphers[@]};i++ )); do
? ? ? ? hint="${ciphers[$i-1]}"
? ? ? ? echo -e "${green}${i}${plain}) ${hint}"
? ? done
? ? read -p "Which cipher you'd select(Default: ${ciphers[0]}):" pick
? ? [ -z "$pick" ] && pick=1
? ? expr ${pick} + 1 &>/dev/null
? ? if [ $? -ne 0 ]; then
? ? ? ? echo -e "[${red}Error${plain}] Please enter a number"
? ? ? ? continue
? ? fi
? ? if [[ "$pick" -lt 1 || "$pick" -gt ${#ciphers[@]} ]]; then
? ? ? ? echo -e "[${red}Error${plain}] Please enter a number between 1 and ${#ciphers[@]}"
? ? ? ? continue
? ? fi
? ? shadowsockscipher=${ciphers[$pick-1]}
? ? echo
? ? echo "---------------------------"
? ? echo "cipher = ${shadowsockscipher}"
? ? echo "---------------------------"
? ? echo
? ? break
? ? done
? ? echo
? ? echo "Press any key to start...or press Ctrl+C to cancel"
? ? char=`get_char`
? ? #Install necessary dependencies
? ? echo -e "[${green}Info${plain}] Checking the EPEL repository..."
? ? if [ ! -f /etc/yum.repos.d/epel.repo ]; then
? ? ? ? yum install -y -q epel-release
? ? fi
? ? [ ! -f /etc/yum.repos.d/epel.repo ] && echo -e "[${red}Error${plain}] Install EPEL repository failed, please check it." && exit 1
? ? [ ! "$(command -v yum-config-manager)" ] && yum install -y -q yum-utils
? ? if [ x"`yum-config-manager epel | grep -w enabled | awk '{print $3}'`" != x"True" ]; then
? ? ? ? yum-config-manager --enable epel
? ? fi
? ? echo -e "[${green}Info${plain}] Checking the EPEL repository complete..."
? ? yum install -y -q unzip openssl openssl-devel gettext gcc autoconf libtool automake make asciidoc xmlto libev-devel pcre pcre-devel git c-ares-devel
}
download() {
? ? local filename=${1}
? ? local cur_dir=`pwd`
? ? if [ -s ${filename} ]; then
? ? ? ? echo -e "[${green}Info${plain}] ${filename} [found]"
? ? else
? ? ? ? echo -e "[${green}Info${plain}] ${filename} not found, download now..."
? ? ? ? wget --no-check-certificate -cq -t3 -T60 -O ${1} ${2}
? ? ? ? if [ $? -eq 0 ]; then
? ? ? ? ? ? echo -e "[${green}Info${plain}] ${filename} download completed..."
? ? ? ? else
? ? ? ? ? ? echo -e "[${red}Error${plain}] Failed to download ${filename}, please download it to ${cur_dir} directory manually and try again."
? ? ? ? ? ? exit 1
? ? ? ? fi
? ? fi
}
# Download latest shadowsocks-libev
download_files(){
? ? cd ${cur_dir}
? ? download "${shadowsocks_libev_ver}.tar.gz" "${download_link}"
? ? download "${libsodium_file}.tar.gz" "${libsodium_url}"
? ? download "${mbedtls_file}-gpl.tgz" "${mbedtls_url}"
? ? download "/etc/init.d/shadowsocks" "${init_script_link}"
}
install_libsodium() {
? ? if [ ! -f /usr/lib/libsodium.a ]; then
? ? ? ? cd ${cur_dir}
? ? ? ? tar zxf ${libsodium_file}.tar.gz
? ? ? ? cd ${libsodium_file}
? ? ? ? ./configure --prefix=/usr && make && make install
? ? ? ? if [ $? -ne 0 ]; then
? ? ? ? ? ? echo -e "[${red}Error${plain}] ${libsodium_file} install failed."
? ? ? ? ? ? exit 1
? ? ? ? fi
? ? else
? ? ? ? echo -e "[${green}Info${plain}] ${libsodium_file} already installed."
? ? fi
}
install_mbedtls() {
? ? if [ ! -f /usr/lib/libmbedtls.a ]; then
? ? ? ? cd ${cur_dir}
? ? ? ? tar xf ${mbedtls_file}-gpl.tgz
? ? ? ? cd ${mbedtls_file}
? ? ? ? make SHARED=1 CFLAGS=-fPIC
? ? ? ? make DESTDIR=/usr install
? ? ? ? if [ $? -ne 0 ]; then
? ? ? ? ? ? echo -e "[${red}Error${plain}] ${mbedtls_file} install failed."
? ? ? ? ? ? exit 1
? ? ? ? fi
? ? else
? ? ? ? echo -e "[${green}Info${plain}] ${mbedtls_file} already installed."
? ? fi
}
# Config shadowsocks
config_shadowsocks(){
? ? local server_value="\"0.0.0.0\""
? ? if get_ipv6; then
? ? ? ? server_value="[\"[::0]\",\"0.0.0.0\"]"
? ? fi
? ? if check_kernel_version && check_kernel_headers; then
? ? ? ? fast_open="true"
? ? else
? ? ? ? fast_open="false"
? ? fi
? ? if [ ! -d /etc/shadowsocks-libev ]; then
? ? ? ? mkdir -p /etc/shadowsocks-libev
? ? fi
? ? cat > /etc/shadowsocks-libev/config.json<<-EOF
{
? ? "server":${server_value},
? ? "server_port":${shadowsocksport},
? ? "password":"${shadowsockspwd}",
? ? "timeout":300,
? ? "user":"nobody",
? ? "method":"${shadowsockscipher}",
? ? "fast_open":${fast_open},
? ? "nameserver":"8.8.8.8",
? ? "mode":"tcp_and_udp"
}
EOF
}
# Firewall set
firewall_set(){
? ? echo -e "[${green}Info${plain}] firewall set start..."
? ? if centosversion 6; then
? ? ? ? /etc/init.d/iptables status > /dev/null 2>&1
? ? ? ? if [ $? -eq 0 ]; then
? ? ? ? ? ? iptables -L -n | grep -i ${shadowsocksport} > /dev/null 2>&1
? ? ? ? ? ? if [ $? -ne 0 ]; then
? ? ? ? ? ? ? ? iptables -I INPUT -m state --state NEW -m tcp -p tcp --dport ${shadowsocksport} -j ACCEPT
? ? ? ? ? ? ? ? iptables -I INPUT -m state --state NEW -m udp -p udp --dport ${shadowsocksport} -j ACCEPT
? ? ? ? ? ? ? ? /etc/init.d/iptables save
? ? ? ? ? ? ? ? /etc/init.d/iptables restart
? ? ? ? ? ? else
? ? ? ? ? ? ? ? echo -e "[${green}Info${plain}] port ${shadowsocksport} has been set up."
? ? ? ? ? ? fi
? ? ? ? else
? ? ? ? ? ? echo -e "[${yellow}Warning${plain}] iptables looks like shutdown or not installed, please manually set it if necessary."
? ? ? ? fi
? ? elif centosversion 7; then
? ? ? ? systemctl status firewalld > /dev/null 2>&1
? ? ? ? if [ $? -eq 0 ]; then
? ? ? ? ? ? firewall-cmd --permanent --zone=public --add-port=${shadowsocksport}/tcp
? ? ? ? ? ? firewall-cmd --permanent --zone=public --add-port=${shadowsocksport}/udp
? ? ? ? ? ? firewall-cmd --reload
? ? ? ? else
? ? ? ? ? ? echo -e "[${yellow}Warning${plain}] firewalld looks like not running or not installed, please enable port ${shadowsocksport} manually if necessary."
? ? ? ? fi
? ? fi
? ? echo -e "[${green}Info${plain}] firewall set completed..."
}
# Install Shadowsocks-libev
install_shadowsocks(){
? ? install_libsodium
? ? install_mbedtls
? ? ldconfig
? ? cd ${cur_dir}
? ? tar zxf ${shadowsocks_libev_ver}.tar.gz
? ? cd ${shadowsocks_libev_ver}
? ? ./configure --disable-documentation
? ? make && make install
? ? if [ $? -eq 0 ]; then
? ? ? ? chmod +x /etc/init.d/shadowsocks
? ? ? ? chkconfig --add shadowsocks
? ? ? ? chkconfig shadowsocks on
? ? ? ? # Start shadowsocks
? ? ? ? /etc/init.d/shadowsocks start
? ? ? ? if [ $? -eq 0 ]; then
? ? ? ? ? ? echo -e "[${green}Info${plain}] Shadowsocks-libev start success!"
? ? ? ? else
? ? ? ? ? ? echo -e "[${yellow}Warning${plain}] Shadowsocks-libev start failure!"
? ? ? ? fi
? ? else
? ? ? ? echo
? ? ? ? echo -e "[${red}Error${plain}] Shadowsocks-libev install failed. please visit https://teddysun.com/357.html and contact."
? ? ? ? exit 1
? ? fi
? ? cd ${cur_dir}
? ? rm -rf ${shadowsocks_libev_ver} ${shadowsocks_libev_ver}.tar.gz
? ? rm -rf ${libsodium_file} ${libsodium_file}.tar.gz
? ? rm -rf ${mbedtls_file} ${mbedtls_file}-gpl.tgz
? ? clear
? ? echo
? ? echo -e "Congratulations, Shadowsocks-libev server install completed!"
? ? 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 Password? ? ? ? : \033[41;37m ${shadowsockspwd} \033[0m"
? ? echo -e "Your Encryption Method: \033[41;37m ${shadowsockscipher} \033[0m"
? ? echo
? ? echo "Welcome to visit:https://teddysun.com/357.html"
? ? echo "Enjoy it!"
? ? echo
}
# Install Shadowsocks-libev
install_shadowsocks_libev(){
? ? disable_selinux
? ? pre_install
? ? download_files
? ? config_shadowsocks
? ? firewall_set
? ? install_shadowsocks
}
# Uninstall Shadowsocks-libev
uninstall_shadowsocks_libev(){
? ? clear
? ? print_info
? ? printf "Are you sure uninstall Shadowsocks-libev? (y/n)"
? ? printf "\n"
? ? read -p "(Default: n):" answer
? ? [ -z ${answer} ] && answer="n"
? ? if [ "${answer}" == "y" ] || [ "${answer}" == "Y" ]; then
? ? ? ? ps -ef | grep -v grep | grep -i "ss-server" > /dev/null 2>&1
? ? ? ? if [ $? -eq 0 ]; then
? ? ? ? ? ? /etc/init.d/shadowsocks stop
? ? ? ? fi
? ? ? ? chkconfig --del shadowsocks
? ? ? ? rm -fr /etc/shadowsocks-libev
? ? ? ? rm -f /usr/local/bin/ss-local
? ? ? ? rm -f /usr/local/bin/ss-tunnel
? ? ? ? rm -f /usr/local/bin/ss-server
? ? ? ? rm -f /usr/local/bin/ss-manager
? ? ? ? rm -f /usr/local/bin/ss-redir
? ? ? ? rm -f /usr/local/bin/ss-nat
? ? ? ? rm -f /usr/local/lib/libshadowsocks-libev.a
? ? ? ? rm -f /usr/local/lib/libshadowsocks-libev.la
? ? ? ? rm -f /usr/local/include/shadowsocks.h
? ? ? ? rm -f /usr/local/lib/pkgconfig/shadowsocks-libev.pc
? ? ? ? rm -f /usr/local/share/man/man1/ss-local.1
? ? ? ? rm -f /usr/local/share/man/man1/ss-tunnel.1
? ? ? ? rm -f /usr/local/share/man/man1/ss-server.1
? ? ? ? rm -f /usr/local/share/man/man1/ss-manager.1
? ? ? ? rm -f /usr/local/share/man/man1/ss-redir.1
? ? ? ? rm -f /usr/local/share/man/man1/ss-nat.1
? ? ? ? rm -f /usr/local/share/man/man8/shadowsocks-libev.8
? ? ? ? rm -fr /usr/local/share/doc/shadowsocks-libev
? ? ? ? rm -f /etc/init.d/shadowsocks
? ? ? ? echo "Shadowsocks-libev uninstall success!"
? ? else
? ? ? ? echo
? ? ? ? echo "uninstall cancelled, nothing to do..."
? ? ? ? echo
? ? fi
}
# Initialization step
action=$1
[ -z $1 ] && action=install
case "$action" in
? ? install|uninstall)
? ? ? ? ${action}_shadowsocks_libev
? ? ? ? ;;
? ? *)
? ? ? ? echo "Arguments error! [${action}]"
? ? ? ? echo "Usage: `basename $0` [install|uninstall]"
? ? ? ? ;;
esac