shadowsocks.sh 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. #!/bin/bash
  2. # Author: yeho <lj2007331 AT gmail.com>
  3. # BLOG: https://blog.linuxeye.com
  4. #
  5. # Notes: OneinStack for CentOS/RadHat 5+ Debian 6+ and Ubuntu 12+
  6. # Install Shadowsocks Server
  7. #
  8. # Project home page:
  9. # http://oneinstack.com
  10. # https://github.com/lj2007331/oneinstack
  11. export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
  12. clear
  13. printf "
  14. #######################################################################
  15. # OneinStack for CentOS/RadHat 6+ Debian 6+ and Ubuntu 12+ #
  16. # Install Shadowsocks Server #
  17. # For more information please visit http://oneinstack.com #
  18. #######################################################################
  19. "
  20. cd src
  21. . ../options.conf
  22. . ../include/color.sh
  23. . ../include/check_os.sh
  24. . ../include/download.sh
  25. # Check if user is root
  26. [ $(id -u) != "0" ] && { echo "${CFAILURE}Error: You must be root to run this script${CEND}"; exit 1; }
  27. PUBLIC_IPADDR=`../include/get_public_ipaddr.py`
  28. [ "$CentOS_RHEL_version" == '5' ] && { echo "${CWARNING}Shadowsocks only support CentOS6,7 or Debian or Ubuntu! ${CEND}"; exit 1; }
  29. Check_shadowsocks() {
  30. [ -f /usr/local/bin/ss-server ] && SS_version=1
  31. [ -f /usr/bin/ssserver -o -f /usr/local/bin/ssserver ] && SS_version=2
  32. }
  33. AddUser_shadowsocks() {
  34. while :; do echo
  35. read -p "Please input password for shadowsocks: " Shadowsocks_password
  36. [ -n "`echo $Shadowsocks_password | grep '[+|&]'`" ] && { echo "${CWARNING}input error,not contain a plus sign (+) and & ${CEND}"; continue; }
  37. (( ${#Shadowsocks_password} >= 5 )) && break || echo "${CWARNING}Shadowsocks password least 5 characters! ${CEND}"
  38. done
  39. }
  40. Iptables_set() {
  41. if [ -e '/etc/sysconfig/iptables' ];then
  42. Shadowsocks_Already_port=`grep -oE '9[0-9][0-9][0-9]' /etc/sysconfig/iptables | head -n 1`
  43. elif [ -e '/etc/iptables.up.rules' ];then
  44. Shadowsocks_Already_port=`grep -oE '9[0-9][0-9][0-9]' /etc/iptables.up.rules | head -n 1`
  45. fi
  46. if [ -n "$Shadowsocks_Already_port" ];then
  47. Shadowsocks_Default_port=`expr $Shadowsocks_Already_port + 1`
  48. else
  49. Shadowsocks_Default_port=9001
  50. fi
  51. while :; do echo
  52. read -p "Please input Shadowsocks port(Default: $Shadowsocks_Default_port): " Shadowsocks_port
  53. [ -z "$Shadowsocks_port" ] && Shadowsocks_port=$Shadowsocks_Default_port
  54. if [ $Shadowsocks_port -ge 9000 >/dev/null 2>&1 -a $Shadowsocks_port -le 10000 >/dev/null 2>&1 ];then
  55. break
  56. else
  57. echo "${CWARNING}input error! Input range: 9001~9999${CEND}"
  58. fi
  59. done
  60. if [ "$OS" == 'CentOS' ];then
  61. if [ -z "`grep -E $Shadowsocks_port /etc/sysconfig/iptables`" ];then
  62. iptables -I INPUT 4 -p udp -m state --state NEW -m udp --dport $Shadowsocks_port -j ACCEPT
  63. iptables -I INPUT 4 -p tcp -m state --state NEW -m tcp --dport $Shadowsocks_port -j ACCEPT
  64. service iptables save
  65. fi
  66. elif [[ $OS =~ ^Ubuntu$|^Debian$ ]];then
  67. if [ -z "`grep -E $Shadowsocks_port /etc/iptables.up.rules`" ];then
  68. iptables -I INPUT 4 -p udp -m state --state NEW -m udp --dport $Shadowsocks_port -j ACCEPT
  69. iptables -I INPUT 4 -p tcp -m state --state NEW -m tcp --dport $Shadowsocks_port -j ACCEPT
  70. iptables-save > /etc/iptables.up.rules
  71. fi
  72. else
  73. echo "${CWARNING}This port is already in iptables${CEND}"
  74. fi
  75. }
  76. Def_parameter() {
  77. if [ "$OS" == 'CentOS' ]; then
  78. while :; do echo
  79. echo 'Please select Shadowsocks server version:'
  80. echo -e "\t${CMSG}1${CEND}. Install Shadowsocks-libev"
  81. echo -e "\t${CMSG}2${CEND}. Install Shadowsocks-python"
  82. read -p "Please input a number:(Default 1 press Enter) " SS_version
  83. [ -z "$SS_version" ] && SS_version=1
  84. if [[ ! $SS_version =~ ^[1-2]$ ]];then
  85. echo "${CWARNING}input error! Please only input number 1,2${CEND}"
  86. else
  87. break
  88. fi
  89. done
  90. AddUser_shadowsocks
  91. Iptables_set
  92. for Package in wget unzip openssl-devel gcc swig python python-devel python-setuptools autoconf libtool libevent automake make curl curl-devel zlib-devel perl perl-devel cpio expat-devel gettext-devel git
  93. do
  94. yum -y install $Package
  95. done
  96. elif [[ $OS =~ ^Ubuntu$|^Debian$ ]];then
  97. SS_version=2
  98. AddUser_shadowsocks
  99. Iptables_set
  100. apt-get -y update
  101. for Package in python-dev python-pip curl wget unzip gcc swig automake make perl cpio git
  102. do
  103. apt-get -y install $Package
  104. done
  105. fi
  106. }
  107. Install_shadowsocks-python() {
  108. src_url=http://mirrors.linuxeye.com/oneinstack/src/ez_setup.py && Download_src
  109. which pip > /dev/null 2>&1
  110. [ $? -ne 0 ] && [ "$OS" == 'CentOS' ] && { python ez_setup.py install; sleep 1; easy_install pip; }
  111. if [ -f /usr/bin/pip ]; then
  112. pip install M2Crypto
  113. pip install greenlet
  114. pip install gevent
  115. pip install shadowsocks
  116. if [ -f /usr/bin/ssserver -o -f /usr/local/bin/ssserver ]; then
  117. /bin/cp ../init.d/Shadowsocks-python-init /etc/init.d/shadowsocks
  118. chmod +x /etc/init.d/shadowsocks
  119. [ "$OS" == 'CentOS' ] && { chkconfig --add shadowsocks; chkconfig shadowsocks on; }
  120. [[ $OS =~ ^Ubuntu$|^Debian$ ]] && update-rc.d shadowsocks defaults
  121. [ ! -e /usr/bin/ssserver -a -e /usr/local/bin/ssserver ] && sed -i 's@Shadowsocks_bin=.*@Shadowsocks_bin=/usr/local/bin/ssserver@' /etc/init.d/shadowsocks
  122. else
  123. echo
  124. echo "${CQUESTION}Shadowsocks-python install failed! Please visit http://oneinstack.com${CEND}"
  125. exit 1
  126. fi
  127. fi
  128. }
  129. Install_shadowsocks-libev() {
  130. git clone https://github.com/shadowsocks/shadowsocks-libev.git
  131. cd shadowsocks-libev
  132. ./configure
  133. make -j ${THREAD} && make install
  134. cd ..
  135. if [ -f /usr/local/bin/ss-server ];then
  136. /bin/cp ../init.d/Shadowsocks-libev-init /etc/init.d/shadowsocks
  137. chmod +x /etc/init.d/shadowsocks
  138. [ "$OS" == 'CentOS' ] && { chkconfig --add shadowsocks; chkconfig shadowsocks on; }
  139. else
  140. echo
  141. echo "${CQUESTION}Shadowsocks-libev install failed! Please visit http://oneinstack.com${CEND}"
  142. exit 1
  143. fi
  144. }
  145. Uninstall_shadowsocks(){
  146. while :; do echo
  147. read -p "Do you want to uninstall Shadowsocks? [y/n]: " Shadowsocks_yn
  148. if [[ ! $Shadowsocks_yn =~ ^[y,n]$ ]];then
  149. echo "${CWARNING}input error! Please only input 'y' or 'n'${CEND}"
  150. else
  151. break
  152. fi
  153. done
  154. if [ "$Shadowsocks_yn" == 'y' ]; then
  155. [ -n "`ps -ef | grep -v grep | grep -iE "ssserver|ss-server"`" ] && /etc/init.d/shadowsocks stop
  156. [ "$OS" == 'CentOS' ] && chkconfig --del shadowsocks
  157. [[ $OS =~ ^Ubuntu$|^Debian$ ]] && update-rc.d -f shadowsocks remove
  158. rm -rf /etc/shadowsocks /var/run/shadowsocks.pid /etc/init.d/shadowsocks
  159. if [ "$SS_version" == '1' ];then
  160. rm -f /usr/local/bin/ss-local
  161. rm -f /usr/local/bin/ss-tunnel
  162. rm -f /usr/local/bin/ss-server
  163. rm -f /usr/local/bin/ss-manager
  164. rm -f /usr/local/bin/ss-redir
  165. rm -f /usr/local/lib/libshadowsocks.a
  166. rm -f /usr/local/lib/libshadowsocks.la
  167. rm -f /usr/local/include/shadowsocks.h
  168. rm -f /usr/local/lib/pkgconfig/shadowsocks-libev.pc
  169. rm -f /usr/local/share/man/man1/ss-local.1
  170. rm -f /usr/local/share/man/man1/ss-tunnel.1
  171. rm -f /usr/local/share/man/man1/ss-server.1
  172. rm -f /usr/local/share/man/man1/ss-manager.1
  173. rm -f /usr/local/share/man/man1/ss-redir.1
  174. rm -f /usr/local/share/man/man8/shadowsocks.8
  175. if [ $? -eq 0 ]; then
  176. echo "${CSUCCESS}Shadowsocks-libev uninstall success! ${CEND}"
  177. else
  178. echo "${CFAILURE}Shadowsocks-libev uninstall failed! ${CEND}"
  179. fi
  180. elif [ "$SS_version" == '2' ];then
  181. pip uninstall -y shadowsocks
  182. if [ $? -eq 0 ]; then
  183. echo "${CSUCCESS}Shadowsocks-python uninstall success! ${CEND}"
  184. else
  185. echo "${CFAILURE}Shadowsocks-python uninstall failed! ${CEND}"
  186. fi
  187. fi
  188. else
  189. echo "${CMSG}Shadowsocks uninstall cancelled! ${CEND}"
  190. fi
  191. }
  192. Config_shadowsocks(){
  193. [ ! -d '/etc/shadowsocks' ] && mkdir /etc/shadowsocks
  194. [ "$SS_version" == '1' ] && cat > /etc/shadowsocks/config.json<<EOF
  195. {
  196. "server":"0.0.0.0",
  197. "server_port":$Shadowsocks_port,
  198. "local_address":"127.0.0.1",
  199. "local_port":1080,
  200. "password":"$Shadowsocks_password",
  201. "timeout":300,
  202. "method":"aes-256-cfb",
  203. }
  204. EOF
  205. [ "$SS_version" == '2' ] && cat > /etc/shadowsocks/config.json<<EOF
  206. {
  207. "server":"0.0.0.0",
  208. "local_address":"127.0.0.1",
  209. "local_port":1080,
  210. "port_password":{
  211. "$Shadowsocks_port":"$Shadowsocks_password"
  212. },
  213. "timeout":300,
  214. "method":"aes-256-cfb",
  215. "fast_open":false
  216. }
  217. EOF
  218. }
  219. AddUser_Config_shadowsocks(){
  220. [ ! -e /etc/shadowsocks/config.json ] && { echo "${CFAILURE}Shadowsocks is not installed! ${CEND}"; exit 1; }
  221. [ -z "`grep \"$Shadowsocks_port\" /etc/shadowsocks/config.json`" ] && sed -i "s@\"port_password\":{@\"port_password\":{\n\t\"$Shadowsocks_port\":\"$Shadowsocks_password\",@" /etc/shadowsocks/config.json || { echo "${CWARNING}This port is already in /etc/shadowsocks/config.json${CEND}"; exit 1; }
  222. }
  223. Print_User_shadowsocks(){
  224. printf "
  225. Your Server IP: ${CMSG}$PUBLIC_IPADDR${CEND}
  226. Your Server Port: ${CMSG}$Shadowsocks_port${CEND}
  227. Your Password: ${CMSG}$Shadowsocks_password${CEND}
  228. Your Local IP: ${CMSG}127.0.0.1${CEND}
  229. Your Local Port: ${CMSG}1080${CEND}
  230. Your Encryption Method: ${CMSG}aes-256-cfb${CEND}
  231. "
  232. }
  233. case "$1" in
  234. install)
  235. Def_parameter
  236. [ "$SS_version" == '1' ] && Install_shadowsocks-libev
  237. [ "$SS_version" == '2' ] && Install_shadowsocks-python
  238. Config_shadowsocks
  239. service shadowsocks start
  240. Print_User_shadowsocks
  241. ;;
  242. adduser)
  243. Check_shadowsocks
  244. if [ "$SS_version" == '2' ];then
  245. AddUser_shadowsocks
  246. Iptables_set
  247. AddUser_Config_shadowsocks
  248. service shadowsocks restart
  249. Print_User_shadowsocks
  250. else
  251. printf "
  252. Sorry, we have no plan to support multi port configuration. Actually you can use multiple instances instead. For example:
  253. ss-server -c /etc/shadowsocks/config1.json -f /var/run/shadowsocks-server/pid1
  254. ss-server -c /etc/shadowsocks/config2.json -f /var/run/shadowsocks-server/pid2
  255. ss-server -c /etc/shadowsocks/config3.json -f /var/run/shadowsocks-server/pid3
  256. "
  257. fi
  258. ;;
  259. uninstall)
  260. Check_shadowsocks
  261. Uninstall_shadowsocks
  262. ;;
  263. *)
  264. echo
  265. echo $"Usage: ${CMSG}$0${CEND} { ${CMSG}install${CEND} | ${CMSG}adduser${CEND} | ${CMSG}uninstall${CEND} }"
  266. echo
  267. exit 1
  268. esac