123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294 |
- #!/bin/bash
- # Author: yeho <lj2007331 AT gmail.com>
- # BLOG: https://blog.linuxeye.cn
- #
- # Notes: OneinStack for CentOS/RadHat 6+ Debian 7+ and Ubuntu 12+
- # Install SS Server
- #
- # Project home page:
- # https://oneinstack.com
- # https://github.com/lj2007331/oneinstack
- export PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin
- clear
- printf "
- #######################################################################
- # OneinStack for CentOS/RadHat 6+ Debian 6+ and Ubuntu 12+ #
- # Install SS Server #
- # For more information please visit https://oneinstack.com #
- #######################################################################
- "
- # Check if user is root
- [ $(id -u) != '0' ] && { echo "${CFAILURE}Error: You must be root to run this script${CEND}"; exit 1; }
- oneinstack_dir=$(dirname "`readlink -f $0`")
- pushd ${oneinstack_dir}/src > /dev/null
- . ../options.conf
- . ../versions.txt
- . ../include/color.sh
- . ../include/check_os.sh
- . ../include/download.sh
- . ../include/python.sh
- PUBLIC_IPADDR=$(../include/get_public_ipaddr.py)
- [ "${CentOS_ver}" == '5' ] && { echo "${CWARNING}SS only support CentOS6,7 or Debian or Ubuntu! ${CEND}"; exit 1; }
- Check_SS() {
- [ -f /usr/local/bin/ss-server ] && ss_option=1
- [ -f ${python_install_dir}/bin/ssserver ] && ss_option=2
- }
- AddUser_SS() {
- while :; do echo
- read -p "Please input password for SS: " SS_password
- [ -n "$(echo ${SS_password} | grep '[+|&]')" ] && { echo "${CWARNING}input error,not contain a plus sign (+) and & ${CEND}"; continue; }
- (( ${#SS_password} >= 5 )) && break || echo "${CWARNING}SS password least 5 characters! ${CEND}"
- done
- }
- Iptables_set() {
- if [ -e '/etc/sysconfig/iptables' ]; then
- SS_Already_port=$(grep -oE '9[0-9][0-9][0-9]' /etc/sysconfig/iptables | head -n 1)
- elif [ -e '/etc/iptables.up.rules' ]; then
- SS_Already_port=$(grep -oE '9[0-9][0-9][0-9]' /etc/iptables.up.rules | head -n 1)
- fi
- if [ -n "${SS_Already_port}" ]; then
- let SS_Default_port="${SS_Already_port}+1"
- else
- SS_Default_port=9001
- fi
- while :; do echo
- read -p "Please input SS port(Default: ${SS_Default_port}): " SS_port
- [ -z "${SS_port}" ] && SS_port=${SS_Default_port}
- if [ ${SS_port} -ge 1 >/dev/null 2>&1 -a ${SS_port} -le 65535 >/dev/null 2>&1 ]; then
- [ -z "$(netstat -tpln | grep :${SS_port}$)" ] && break || echo "${CWARNING}This port is already used! ${CEND}"
- else
- echo "${CWARNING}input error! Input range: 1~65535${CEND}"
- fi
- done
- if [ "${OS}" == 'CentOS' ]; then
- if [ -n "`grep 'dport 80 ' /etc/sysconfig/iptables`" -a -z "$(grep -E ${SS_port} /etc/sysconfig/iptables)" ]; then
- iptables -I INPUT 4 -p udp -m state --state NEW -m udp --dport ${SS_port} -j ACCEPT
- iptables -I INPUT 4 -p tcp -m state --state NEW -m tcp --dport ${SS_port} -j ACCEPT
- service iptables save
- fi
- elif [[ ${OS} =~ ^Ubuntu$|^Debian$ ]]; then
- if [ -n "`grep 'dport 80 ' /etc/iptables.up.rules`" -a -z "$(grep -E ${SS_port} /etc/iptables.up.rules)" ]; then
- iptables -I INPUT 4 -p udp -m state --state NEW -m udp --dport ${SS_port} -j ACCEPT
- iptables -I INPUT 4 -p tcp -m state --state NEW -m tcp --dport ${SS_port} -j ACCEPT
- iptables-save > /etc/iptables.up.rules
- fi
- fi
- }
- Def_parameter() {
- while :; do echo
- echo "Please select SS server version:"
- echo -e "\t${CMSG}1${CEND}. Install SS-libev"
- echo -e "\t${CMSG}2${CEND}. Install SS-python"
- read -p "Please input a number:(Default 1 press Enter) " ss_option
- [ -z "${ss_option}" ] && ss_option=1
- if [[ ! "${ss_option}" =~ ^[1-2]$ ]]; then
- echo "${CWARNING}input error! Please only input number 1~2${CEND}"
- else
- break
- fi
- done
- AddUser_SS
- Iptables_set
- if [ "${OS}" == "CentOS" ]; then
- pkgList="wget unzip openssl-devel gcc swig autoconf libtool libevent automake make curl curl-devel zlib-devel perl perl-devel cpio expat-devel gettext-devel git asciidoc xmlto c-ares-devel pcre-devel udns-devel libev-devel"
- for Package in ${pkgList}; do
- yum -y install ${Package}
- done
- elif [[ "${OS}" =~ ^Ubuntu$|^Debian$ ]]; then
- apt-get -y update
- pkgList="curl wget unzip gcc swig automake make perl cpio git libudns-dev libev-dev gettext build-essential autoconf libtool libpcre3-dev asciidoc xmlto libc-ares-dev"
- for Package in ${pkgList}; do
- apt-get -y install $Package
- done
- fi
- }
- Install_SS-python() {
- [ ! -e "${python_install_dir}/bin/python" ] && Install_Python
- ${python_install_dir}/bin/pip install M2Crypto
- ${python_install_dir}/bin/pip install greenlet
- ${python_install_dir}/bin/pip install gevent
- ${python_install_dir}/bin/pip install shadowsocks
- if [ -f ${python_install_dir}/bin/ssserver ]; then
- /bin/cp ../init.d/SS-python-init /etc/init.d/shadowsocks
- chmod +x /etc/init.d/shadowsocks
- sed -i "s@SS_bin=.*@SS_bin=${python_install_dir}/bin/ssserver@" /etc/init.d/shadowsocks
- [ "${OS}" == "CentOS" ] && { chkconfig --add shadowsocks; chkconfig shadowsocks on; }
- [[ "${OS}" =~ ^Ubuntu$|^Debian$ ]] && update-rc.d shadowsocks defaults
- else
- echo
- echo "${CQUESTION}SS-python install failed! Please visit https://oneinstack.com${CEND}"
- exit 1
- fi
- }
- Install_SS-libev() {
- src_url=http://mirrors.linuxeye.com/oneinstack/src/shadowsocks-libev-3.1.3.tar.gz && Download_src
- src_url=http://mirrors.linuxeye.com/oneinstack/src/libsodium-${libsodium_ver}.tar.gz && Download_src
- src_url=http://mirrors.linuxeye.com/oneinstack/src/mbedtls-2.8.0-apache.tgz && Download_src
- if [ ! -e "/usr/local/lib/libsodium.la" ]; then
- tar xzf libsodium-${libsodium_ver}.tar.gz
- pushd libsodium-${libsodium_ver}
- ./configure
- make -j ${THREAD} && make install
- popd
- rm -rf libsodium-${libsodium_ver}
- fi
- tar xzf mbedtls-2.8.0-apache.tgz
- pushd mbedtls-2.8.0
- make SHARED=1 CFLAGS=-fPIC
- make DESTDIR=/usr install
- popd
- tar xzf shadowsocks-libev-3.1.3.tar.gz
- pushd shadowsocks-libev-3.1.3
- make clean
- ./configure
- make -j ${THREAD} && make install
- popd
- [ -z "`grep /usr/local/lib /etc/ld.so.conf.d/*.conf`" ] && echo '/usr/local/lib' > /etc/ld.so.conf.d/local.conf
- ldconfig
- if [ -f /usr/local/bin/ss-server ]; then
- if [ "${OS}" == "CentOS" ]; then
- /bin/cp ../init.d/SS-libev-init-CentOS /etc/init.d/shadowsocks
- chkconfig --add shadowsocks
- chkconfig shadowsocks on
- elif [[ "${OS}" =~ ^Ubuntu$|^Debian$ ]]; then
- /bin/cp ../init.d/SS-libev-init-Ubuntu /etc/init.d/shadowsocks
- update-rc.d shadowsocks defaults
- fi
- else
- echo
- echo "${CQUESTION}SS-libev install failed! Please visit https://oneinstack.com${CEND}"
- exit 1
- fi
- }
- Uninstall_SS() {
- while :; do echo
- read -p "Do you want to uninstall SS? [y/n]: " SS_yn
- if [[ ! "${SS_yn}" =~ ^[y,n]$ ]]; then
- echo "${CWARNING}input error! Please only input 'y' or 'n'${CEND}"
- else
- break
- fi
- done
- if [ "${SS_yn}" == 'y' ]; then
- [ -n "$(ps -ef | grep -v grep | grep -iE "ssserver|ss-server")" ] && /etc/init.d/shadowsocks stop
- [ "${OS}" == "CentOS" ] && chkconfig --del shadowsocks
- [[ "${OS}" =~ ^Ubuntu$|^Debian$ ]] && update-rc.d -f shadowsocks remove
- rm -rf /etc/shadowsocks /var/run/shadowsocks.pid /etc/init.d/shadowsocks
- if [ "${ss_option}" == '1' ]; then
- rm -f /usr/local/bin/{ss-local,ss-tunnel,ss-server,ss-manager,ss-redir}
- rm -f /usr/local/lib/libshadowsocks.*
- 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,ss-tunnel.1,ss-server.1,ss-manager.1,ss-redir.1,shadowsocks.8}
- if [ $? -eq 0 ]; then
- echo "${CSUCCESS}SS-libev uninstall successful! ${CEND}"
- else
- echo "${CFAILURE}SS-libev uninstall failed! ${CEND}"
- fi
- elif [ "${ss_option}" == '2' ]; then
- ${python_install_dir}/bin/pip uninstall -y shadowsocks
- if [ $? -eq 0 ]; then
- echo "${CSUCCESS}SS-python uninstall successful! ${CEND}"
- else
- echo "${CFAILURE}SS-python uninstall failed! ${CEND}"
- fi
- fi
- fi
- }
- Config_SS() {
- [ ! -d "/etc/shadowsocks" ] && mkdir /etc/shadowsocks
- [ "${ss_option}" == '1' ] && cat > /etc/shadowsocks/config.json << EOF
- {
- "server":"0.0.0.0",
- "server_port":${SS_port},
- "local_address":"127.0.0.1",
- "local_port":1080,
- "password":"${SS_password}",
- "timeout":300,
- "method":"aes-256-cfb",
- }
- EOF
- [ "${ss_option}" == '2' ] && cat > /etc/shadowsocks/config.json << EOF
- {
- "server":"0.0.0.0",
- "local_address":"127.0.0.1",
- "local_port":1080,
- "port_password":{
- "${SS_port}":"${SS_password}"
- },
- "timeout":300,
- "method":"aes-256-cfb",
- "fast_open":false
- }
- EOF
- }
- AddUser_Config_SS() {
- [ ! -e /etc/shadowsocks/config.json ] && { echo "${CFAILURE}SS is not installed! ${CEND}"; exit 1; }
- [ -z "$(grep \"${SS_port}\" /etc/shadowsocks/config.json)" ] && sed -i "s@\"port_password\":{@\"port_password\":{\n\t\"${SS_port}\":\"${SS_password}\",@" /etc/shadowsocks/config.json || { echo "${CWARNING}This port is already in /etc/shadowsocks/config.json${CEND}"; exit 1; }
- }
- Print_User_SS() {
- printf "
- Your Server IP: ${CMSG}${PUBLIC_IPADDR}${CEND}
- Your Server Port: ${CMSG}${SS_port}${CEND}
- Your Password: ${CMSG}${SS_password}${CEND}
- Your Local IP: ${CMSG}127.0.0.1${CEND}
- Your Local Port: ${CMSG}1080${CEND}
- Your Encryption Method: ${CMSG}aes-256-cfb${CEND}
- "
- }
- case "$1" in
- install)
- Def_parameter
- [ "${ss_option}" == '1' ] && Install_SS-libev
- [ "${ss_option}" == '2' ] && Install_SS-python
- Config_SS
- service shadowsocks start
- Print_User_SS
- ;;
- adduser)
- Check_SS
- if [ "${ss_option}" == '2' ]; then
- AddUser_SS
- Iptables_set
- AddUser_Config_SS
- service shadowsocks restart
- Print_User_SS
- else
- printf "
- Sorry, we have no plan to support multi port configuration. Actually you can use multiple instances instead. For example:
- ss-server -c /etc/shadowsocks/config1.json -f /var/run/shadowsocks-server/pid1
- ss-server -c /etc/shadowsocks/config2.json -f /var/run/shadowsocks-server/pid2
- "
- fi
- ;;
- uninstall)
- Check_SS
- Uninstall_SS
- ;;
- *)
- echo
- echo "Usage: ${CMSG}$0${CEND} { ${CMSG}install${CEND} | ${CMSG}adduser${CEND} | ${CMSG}uninstall${CEND} }"
- echo
- exit 1
- esac
|