v2ray_ss_conf.sh 5.9 KB

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