v2ray_ss_conf.sh 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. #!/bin/bash
  2. # Shadowsocks 和 V2Ray 简易配置: 生成和显示二维码 短网址: https://git.io/v2ray.ss
  3. # Usage: bash <(curl -L -s https://git.io/v2ray.ss)
  4. let v2ray_port=$RANDOM+9999
  5. UUID=$(cat /proc/sys/kernel/random/uuid)
  6. let ss_port=$RANDOM+8888
  7. ss_passwd=$(date | md5sum | head -c 6)
  8. cur_dir=$(pwd)
  9. if [ ! -e '/var/ip_addr' ]; then
  10. echo -n $(curl -4 ip.sb) > /var/ip_addr
  11. fi
  12. serverip=$(cat /var/ip_addr)
  13. # 修改端口号
  14. setport(){
  15. echo_SkyBlue ":: 1.请修改 V2ray 服务器端端口号,随机端口:${RedBG} ${v2ray_port} "
  16. read -p "请输入数字(100--60000): " num
  17. if [[ ${num} -ge 100 ]] && [[ ${num} -le 60000 ]]; then
  18. v2ray_port=$num
  19. fi
  20. }
  21. # debian 9 bbr 设置打开
  22. sysctl_config() {
  23. sed -i '/net.core.default_qdisc/d' /etc/sysctl.conf
  24. sed -i '/net.ipv4.tcp_congestion_control/d' /etc/sysctl.conf
  25. echo "net.core.default_qdisc = fq" >> /etc/sysctl.conf
  26. echo "net.ipv4.tcp_congestion_control = bbr" >> /etc/sysctl.conf
  27. sysctl -p >/dev/null 2>&1
  28. }
  29. ss_enable(){
  30. cat <<EOF >/etc/rc.local
  31. #!/bin/sh -e # ipv6 支持 -s ::0
  32. ss-server -s 0.0.0.0 -p 40000 -k ${ss_passwd} -m aes-256-gcm -t 300 -s ::0 >> /var/log/ss-server.log &
  33. exit 0
  34. EOF
  35. }
  36. conf_shadowsocks(){
  37. echo_SkyBlue ":: 2.请修改 Shadowsocks 服务器端端口号,随机端口: ${RedBG} ${ss_port} "
  38. read -p "请输入数字(100--60000): " num
  39. if [[ ${num} -ge 100 ]] && [[ ${num} -le 60000 ]]; then
  40. ss_port=$num
  41. fi
  42. echo_SkyBlue ":: 3.请修改 Shadowsocks 的密码,随机密码: ${RedBG} ${ss_passwd} "
  43. read -p "请输入你要的密码(按回车不修改): " new
  44. if [[ ! -z "${new}" ]]; then
  45. ss_passwd="${new}"
  46. echo -e "修改密码: ${GreenBG} ${ss_passwd} ${Font}"
  47. fi
  48. # 如果 Shadowsocks 没有安装,安装Shadowsocks
  49. if [ ! -e '/usr/local/bin/ss-server' ]; then
  50. sysctl_config
  51. ss_enable
  52. bash <(curl -L -s git.io/fhExJ)
  53. fi
  54. old_ss_port=$(cat /etc/rc.local | grep ss-server | awk '{print $5}')
  55. old_passwd=$(cat /etc/rc.local | grep ss-server | awk '{print $7}')
  56. method=$(cat /etc/rc.local | grep ss-server | awk '{print $9}')
  57. sed -i "s/${old_ss_port}/${ss_port}/g" "/etc/rc.local"
  58. sed -i "s/${old_passwd}/${ss_passwd}/g" "/etc/rc.local"
  59. sed -i "s/ss-server -s 127.0.0.1/ss-server -s 0.0.0.0/g" "/etc/rc.local"
  60. systemctl stop rc-local
  61. # 简化判断系统 debian/centos 族群
  62. if [ -e '/etc/redhat-release' ]; then
  63. mv /etc/rc.local /etc/rc.d/rc.local
  64. ln -s /etc/rc.d/rc.local /etc/rc.local
  65. chmod +x /etc/rc.d/rc.local
  66. systemctl enable rc-local
  67. else
  68. chmod +x /etc/rc.local
  69. systemctl enable rc-local
  70. fi
  71. systemctl restart rc-local
  72. echo_Yellow ":: Shadowsocks 服务 加密协议/密码/IP/端口 信息!"
  73. # ss://<<base64_shadowsocks.conf>>
  74. echo "${method}:${ss_passwd}@${serverip}:${ss_port}" | tee ${cur_dir}/base64_shadowsocks.conf
  75. }
  76. conf_v2ray(){
  77. # 如果 v2ray 没有安装,安装v2ray
  78. if [ ! -e '/etc/v2ray/config.json' ]; then
  79. bash <(curl -L -s https://install.direct/go.sh)
  80. fi
  81. echo_SkyBlue ":: V2ray 服务 IP/端口/UUID等信息!"
  82. # vmess://<<base64_v2ray_vmess.json>>
  83. cat <<EOF | tee ${cur_dir}/base64_v2ray_vmess.json
  84. {
  85. "v": "2",
  86. "ps": "v2ray",
  87. "add": "${serverip}",
  88. "port": "${v2ray_port}",
  89. "id": "${UUID}",
  90. "aid": "64",
  91. "net": "kcp",
  92. "type": "srtp",
  93. "host": "",
  94. "path": "",
  95. "tls": ""
  96. }
  97. EOF
  98. # v2ray服务端mKcp配 /etc/v2ray/config.json
  99. cat <<EOF >/etc/v2ray/config.json
  100. {
  101. "inbounds": [
  102. {
  103. "port": $v2ray_port,
  104. "protocol": "vmess",
  105. "settings": {
  106. "clients": [
  107. {
  108. "id": "${UUID}",
  109. "level": 1,
  110. "alterId": 64
  111. }
  112. ]
  113. },
  114. "streamSettings": {
  115. "tcpSettings": {},
  116. "quicSettings": {},
  117. "tlsSettings": {},
  118. "network": "kcp",
  119. "kcpSettings": {
  120. "mtu": 1350,
  121. "tti": 50,
  122. "header": {
  123. "type": "srtp"
  124. },
  125. "readBufferSize": 2,
  126. "writeBufferSize": 2,
  127. "downlinkCapacity": 100,
  128. "congestion": false,
  129. "uplinkCapacity": 100
  130. },
  131. "wsSettings": {},
  132. "httpSettings": {},
  133. "security": "none"
  134. }
  135. }
  136. ],
  137. "log": {
  138. "access": "/var/log/v2ray/access.log",
  139. "loglevel": "info",
  140. "error": "/var/log/v2ray/error.log"
  141. },
  142. "routing": {
  143. "rules": [
  144. {
  145. "ip": [
  146. "0.0.0.0/8",
  147. "10.0.0.0/8",
  148. "100.64.0.0/10",
  149. "169.254.0.0/16",
  150. "172.16.0.0/12",
  151. "192.0.0.0/24",
  152. "192.0.2.0/24",
  153. "192.168.0.0/16",
  154. "198.18.0.0/15",
  155. "198.51.100.0/24",
  156. "203.0.113.0/24",
  157. "::1/128",
  158. "fc00::/7",
  159. "fe80::/10"
  160. ],
  161. "type": "field",
  162. "outboundTag": "blocked"
  163. }
  164. ]
  165. },
  166. "outbounds": [
  167. {
  168. "protocol": "freedom",
  169. "settings": {}
  170. },
  171. {
  172. "protocol": "blackhole",
  173. "tag": "blocked",
  174. "settings": {}
  175. }
  176. ]
  177. }
  178. EOF
  179. systemctl restart v2ray
  180. }
  181. # 定义文字颜色
  182. Green="\033[32m" && Red="\033[31m" && GreenBG="\033[42;37m" && RedBG="\033[41;37m"
  183. Font="\033[0m" && Yellow="\033[0;33m" && SkyBlue="\033[0;36m"
  184. echo_SkyBlue(){
  185. echo -e "${SkyBlue}$1${Font}"
  186. }
  187. echo_Yellow(){
  188. echo -e "${Yellow}$1${Font}"
  189. }
  190. # 显示手机客户端二维码
  191. conf_QRcode(){
  192. st="$(cat ${cur_dir}/base64_shadowsocks.conf)"
  193. ss_b64=$(echo -n $st | base64)
  194. shadowsocks_ss="ss://${ss_b64}"
  195. v2_b64=$(base64 -w0 ${cur_dir}/base64_v2ray_vmess.json)
  196. v2ray_vmess="vmess://${v2_b64}"
  197. echo_SkyBlue ":: Shadowsocks 服务器二维码,请手机扫描!"
  198. echo -n $shadowsocks_ss | qrencode -o - -t UTF8
  199. echo_Yellow $shadowsocks_ss
  200. echo
  201. echo_SkyBlue ":: V2rayNG 手机配置二维码,请手机扫描!"
  202. echo -n $v2ray_vmess | qrencode -o - -t UTF8
  203. echo_SkyBlue ":: V2rayN Windows 客户端 Vmess 协议配置"
  204. echo $v2ray_vmess
  205. echo_SkyBlue ":: SSH工具推荐Git-Bash 2.20; GCP_SSH(浏览器)字体Courier New 二维码显示正常!"
  206. echo_Yellow ":: 命令${RedBG} bash <(curl -L -s https://git.io/v2ray.ss) setup ${Font}设置修改端口密码和UUID"
  207. }
  208. # 设置 v2ray 端口和UUID
  209. set_v2ray_ss(){
  210. setport
  211. conf_shadowsocks
  212. conf_v2ray
  213. }
  214. clear
  215. # 首次运行脚本,设置 端口和UUID
  216. if [ ! -e 'base64_v2ray_vmess.json' ]; then
  217. # 简化判断系统 debian/centos 族群
  218. if [ -e '/etc/redhat-release' ]; then
  219. yum update -y && yum install -y qrencode wget vim
  220. else
  221. apt update && apt install -y qrencode
  222. fi
  223. set_v2ray_ss
  224. fi
  225. # 命令 bash v2ray_ss_conf.sh setup 设置 端口和UUID
  226. if [[ $# > 0 ]]; then
  227. key="$1"
  228. case $key in
  229. setup)
  230. set_v2ray_ss
  231. ;;
  232. esac
  233. fi
  234. echo_SkyBlue ":: Shadowsocks 和 V2Ray 简易配置: 生成和显示二维码 By 蘭雅sRGB "
  235. echo_Yellow ":: 一键命令 ${RedBG} bash <(curl -L -s https://git.io/v2ray.ss) "
  236. # 输出ss和v2ray配置和二维码
  237. conf_QRcode 2>&1 | tee ${cur_dir}/v2ray_ss.log