sskcp.sh 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. #!/bin/bash
  2. SERVER_IP=188.188.188.188
  3. PORT=1999
  4. PASSWORD=wg2999
  5. SS_PORT=40000
  6. SOCKS5_PORT=1080
  7. start(){
  8. # SS + KcpTun + Udp2RAW
  9. udp2raw -c -r$SERVER_IP:$PORT -l0.0.0.0:4000 -k $PASSWORD --raw-mode faketcp -a >> /var/log/udp2raw.log &
  10. kcp-client -r 127.0.0.1:4000 -l :$SS_PORT --key $PASSWORD -mode fast2 -mtu 1300 >> /var/log/kcp-client.log 2>&1 &
  11. # ss-local -s 服务器IP地址 -p 服务器端口 -b 绑定本地IP -l 本地端口 -k 密码 -m 加密方式 [-c 配置文件]
  12. ss-local -s 127.0.0.1 -p $SS_PORT -b 0.0.0.0 -l $SOCKS5_PORT -k $PASSWORD -m aes-256-gcm -t 300 >> /var/log/ss-local.log &
  13. # status
  14. }
  15. stop(){
  16. killall -9 kcp-client
  17. killall -9 udp2raw
  18. killall -9 ss-local
  19. }
  20. restart(){
  21. stop
  22. start
  23. }
  24. help(){
  25. echo -e "${SkyBlue}:: Source: ${Green}https://git.io/sskcp.sh ${Font}By 蘭雅sRGB"
  26. echo -e "${SkyBlue}:: Usage: ${GreenBG} bash sskcp.sh ${Yellow} [start|stop|restart|service|set] ${Font}"
  27. echo
  28. }
  29. status(){
  30. # log 和 命令行参数
  31. cat /var/log/udp2raw.log | tail
  32. cat /var/log/kcp-client.log | tail
  33. cat /var/log/ss-local.log | tail
  34. echo
  35. if [[ -e /etc/openwrt_release ]]; then
  36. ps | grep -e udp2raw -e kcp-client -e ss-local
  37. else
  38. ps ax | grep --color=auto -e udp2raw -e kcp-client -e ss-local
  39. fi
  40. echo
  41. }
  42. setconf()
  43. {
  44. echo -e "${SkyBlue}:: 修改脚本sskcp.sh记录参数,按${RedBG}<Enter>${SkyBlue}不修改! ${Yellow}"
  45. head -n 6 sskcp.sh | tail -n 4 && echo -e "${SkyBlue}"
  46. read -p ":: 1.请输入远程服务器IP: " sv_ip
  47. read -p ":: 2.请输入udp2raw 端口: " port
  48. read -p ":: 3.请输入套接转发密码: " passwd
  49. read -p ":: 4.请输入 SS 服务端口: " ss_port
  50. if [[ ! -z "${sv_ip}" ]]; then
  51. sed -i "s/^SERVER_IP=.*/SERVER_IP=${sv_ip}/g" "sskcp.sh"
  52. fi
  53. if [[ ! -z "${port}" ]]; then
  54. sed -i "s/^PORT=.*/PORT=${port}/g" "sskcp.sh"
  55. fi
  56. if [[ ! -z "${passwd}" ]]; then
  57. sed -i "s/^PASSWORD=.*/PASSWORD=${passwd}/g" "sskcp.sh"
  58. fi
  59. if [[ ! -z "${ss_port}" ]]; then
  60. sed -i "s/^SS_PORT=.*/SS_PORT=${ss_port}/g" "sskcp.sh"
  61. fi
  62. echo -e "${Yellow}" && head -n 7 sskcp.sh | tail -n 5 && echo -e "${Font}"
  63. }
  64. system_def(){
  65. Green="\033[32m" && Red="\033[31m" && GreenBG="\033[42;37m" && RedBG="\033[41;37m"
  66. Font="\033[0m" && Yellow="\033[0;33m" && SkyBlue="\033[0;36m"
  67. }
  68. systemd_service(){
  69. # 安装启动服务
  70. cat <<EOF >/usr/lib/systemd/system/sskcp.service
  71. [Unit]
  72. Description=sskcp.sh Service
  73. After=network.target
  74. [Service]
  75. Type=forking
  76. User=root
  77. ExecStart=nohup /root/sskcp.sh start &
  78. ExecReload=sh /root/sskcp.sh stop
  79. [Install]
  80. WantedBy=multi-user.target
  81. EOF
  82. chmod +x /root/sskcp.sh
  83. systemctl enable sskcp.service
  84. systemctl start sskcp.service
  85. systemctl status sskcp.service
  86. }
  87. # 脚本命令参数
  88. system_def
  89. if [[ $# > 0 ]]; then
  90. key="$1"
  91. case $key in
  92. start)
  93. start
  94. ;;
  95. stop)
  96. stop
  97. ;;
  98. restart)
  99. restart
  100. ;;
  101. service)
  102. systemd_service
  103. ;;
  104. set)
  105. setconf
  106. ;;
  107. esac
  108. else
  109. status
  110. fi
  111. help