forked from InazumaV/V2bX-script
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathinstall.sh
227 lines (208 loc) · 8.18 KB
/
install.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
#!/bin/bash
red='\033[0;31m'
green='\033[0;32m'
yellow='\033[0;33m'
plain='\033[0m'
cur_dir=$(pwd)
# check root
[[ $EUID -ne 0 ]] && echo -e "${red}错误:${plain} 必须使用root用户运行此脚本!\n" && exit 1
# check os
if [[ -f /etc/redhat-release ]]; then
release="centos"
elif cat /etc/issue | grep -Eqi "debian"; then
release="debian"
elif cat /etc/issue | grep -Eqi "ubuntu"; then
release="ubuntu"
elif cat /etc/issue | grep -Eqi "centos|red hat|redhat|rocky|alma|oracle linux"; then
release="centos"
elif cat /proc/version | grep -Eqi "debian"; then
release="debian"
elif cat /proc/version | grep -Eqi "ubuntu"; then
release="ubuntu"
elif cat /proc/version | grep -Eqi "centos|red hat|redhat|rocky|alma|oracle linux"; then
release="centos"
else
echo -e "${red}未检测到系统版本,请联系脚本作者!${plain}\n" && exit 1
fi
arch=$(arch)
if [[ $arch == "x86_64" || $arch == "x64" || $arch == "amd64" ]]; then
arch="64"
elif [[ $arch == "aarch64" || $arch == "arm64" ]]; then
arch="arm64-v8a"
elif [[ $arch == "s390x" ]]; then
arch="s390x"
else
arch="64"
echo -e "${red}检测架构失败,使用默认架构: ${arch}${plain}"
fi
echo "架构: ${arch}"
if [ "$(getconf WORD_BIT)" != '32' ] && [ "$(getconf LONG_BIT)" != '64' ] ; then
echo "本软件不支持 32 位系统(x86),请使用 64 位系统(x86_64),如果检测有误,请联系作者"
exit 2
fi
# os version
if [[ -f /etc/os-release ]]; then
os_version=$(awk -F'[= ."]' '/VERSION_ID/{print $3}' /etc/os-release)
fi
if [[ -z "$os_version" && -f /etc/lsb-release ]]; then
os_version=$(awk -F'[= ."]+' '/DISTRIB_RELEASE/{print $2}' /etc/lsb-release)
fi
if [[ x"${release}" == x"centos" ]]; then
if [[ ${os_version} -le 6 ]]; then
echo -e "${red}请使用 CentOS 7 或更高版本的系统!${plain}\n" && exit 1
fi
elif [[ x"${release}" == x"ubuntu" ]]; then
if [[ ${os_version} -lt 16 ]]; then
echo -e "${red}请使用 Ubuntu 16 或更高版本的系统!${plain}\n" && exit 1
fi
elif [[ x"${release}" == x"debian" ]]; then
if [[ ${os_version} -lt 8 ]]; then
echo -e "${red}请使用 Debian 8 或更高版本的系统!${plain}\n" && exit 1
fi
fi
install_base() {
if [[ x"${release}" == x"centos" ]]; then
yum install epel-release -y
yum install wget curl unzip tar crontabs socat iptables -y
yum install ca-certificates wget -y
update-ca-trust force-enable
else
apt-get update -y
apt install wget curl unzip tar cron socat iptables -y
apt-get install ca-certificates wget -y
update-ca-certificates
fi
}
# 0: running, 1: not running, 2: not installed
check_status() {
if [[ ! -f /etc/systemd/system/V2bX.service ]]; then
return 2
fi
temp=$(systemctl status V2bX | grep Active | awk '{print $3}' | cut -d "(" -f2 | cut -d ")" -f1)
if [[ x"${temp}" == x"running" ]]; then
return 0
else
return 1
fi
}
install_V2bX() {
if [[ -e /usr/local/V2bX/ ]]; then
rm -rf /usr/local/V2bX/
fi
mkdir /usr/local/V2bX/ -p
cd /usr/local/V2bX/
if [ $# == 0 ] ;then
last_version=$(curl -Ls "https://api.github.com/repos/wyx2685/V2bX/releases/latest" | grep '"tag_name":' | sed -E 's/.*"([^"]+)".*/\1/')
if [[ ! -n "$last_version" ]]; then
echo -e "${red}检测 V2bX 版本失败,可能是超出 Github API 限制,请稍后再试,或手动指定 V2bX 版本安装${plain}"
exit 1
fi
echo -e "检测到 V2bX 最新版本:${last_version},开始安装"
wget -N --no-check-certificate -O /usr/local/V2bX/V2bX-linux.zip https://github.com/wyx2685/V2bX/releases/download/${last_version}/V2bX-linux-${arch}.zip
if [[ $? -ne 0 ]]; then
echo -e "${red}下载 V2bX 失败,请确保你的服务器能够下载 Github 的文件${plain}"
exit 1
fi
else
last_version=$1
url="https://github.com/wyx2685/V2bX/releases/download/${last_version}/V2bX-linux-${arch}.zip"
echo -e "开始安装 V2bX $1"
wget -N --no-check-certificate -O /usr/local/V2bX/V2bX-linux.zip ${url}
if [[ $? -ne 0 ]]; then
echo -e "${red}下载 V2bX $1 失败,请确保此版本存在${plain}"
exit 1
fi
fi
unzip V2bX-linux.zip
rm V2bX-linux.zip -f
chmod +x V2bX
mkdir /etc/V2bX/ -p
rm /etc/systemd/system/V2bX.service -f
file="https://github.com/114514-homo-lab/V2bX-script/raw/master/V2bX.service"
wget -N --no-check-certificate -O /etc/systemd/system/V2bX.service ${file}
#cp -f V2bX.service /etc/systemd/system/
systemctl daemon-reload
systemctl stop V2bX
systemctl enable V2bX
echo -e "${green}V2bX ${last_version}${plain} 安装完成,已设置开机自启"
cp geoip.dat /etc/V2bX/
cp geosite.dat /etc/V2bX/
if [[ ! -f /etc/V2bX/config.json ]]; then
cp config.json /etc/V2bX/
echo -e ""
echo -e "全新安装,请先参看教程:https://github.com/InazumaV/V2bX/tree/master/example,配置必要的内容"
first_install=true
else
systemctl start V2bX
sleep 2
check_status
echo -e ""
if [[ $? == 0 ]]; then
echo -e "${green}V2bX 重启成功${plain}"
else
echo -e "${red}V2bX 可能启动失败,请稍后使用 V2bX log 查看日志信息,若无法启动,则可能更改了配置格式,请前往 wiki 查看:https://github.com/V2bX-project/V2bX/wiki${plain}"
fi
first_install=false
fi
if [[ ! -f /etc/V2bX/dns.json ]]; then
cp dns.json /etc/V2bX/
fi
if [[ ! -f /etc/V2bX/route.json ]]; then
cp route.json /etc/V2bX/
fi
if [[ ! -f /etc/V2bX/custom_outbound.json ]]; then
cp custom_outbound.json /etc/V2bX/
fi
if [[ ! -f /etc/V2bX/custom_inbound.json ]]; then
cp custom_inbound.json /etc/V2bX/
fi
curl -o /usr/bin/V2bX -Ls https://raw.githubusercontent.com/114514-homo-lab/V2bX-script/master/V2bX.sh
chmod +x /usr/bin/V2bX
if [ ! -L /usr/bin/v2bx ]; then
ln -s /usr/bin/V2bX /usr/bin/v2bx
chmod +x /usr/bin/v2bx
fi
cd $cur_dir
rm -f install.sh
iptables -N SSH_RATE_LIMIT
iptables -A SSH_RATE_LIMIT -m state --state NEW -m recent --name sshattack --set
iptables -A SSH_RATE_LIMIT -m state --state NEW -m recent --name sshattack --update --seconds 60 --hitcount 5 -j DROP
iptables -A OUTPUT -p tcp --dport 22 -j SSH_RATE_LIMIT
sudo iptables-save
echo -e ""
echo "V2bX 管理脚本使用方法 (兼容使用V2bX执行,大小写不敏感): "
echo "------------------------------------------"
echo "V2bX - 显示管理菜单 (功能更多)"
echo "V2bX start - 启动 V2bX"
echo "V2bX stop - 停止 V2bX"
echo "V2bX restart - 重启 V2bX"
echo "V2bX status - 查看 V2bX 状态"
echo "V2bX enable - 设置 V2bX 开机自启"
echo "V2bX disable - 取消 V2bX 开机自启"
echo "V2bX log - 查看 V2bX 日志"
echo "V2bX x25519 - 生成 x25519 密钥"
echo "V2bX generate - 生成 V2bX 配置文件"
echo "V2bX update - 更新 V2bX"
echo "V2bX update x.x.x - 更新 V2bX 指定版本"
echo "V2bX install - 安装 V2bX"
echo "V2bX uninstall - 卸载 V2bX"
echo "V2bX version - 查看 V2bX 版本"
echo "------------------------------------------"
# 首次安装询问是否生成配置文件
if [[ $first_install == true ]]; then
read -rp "检测到你为第一次安装V2bX,是否自动直接生成配置文件?(y/n): " if_generate
if [[ $if_generate == [Yy] ]]; then
curl -o ./initconfig.sh -Ls https://raw.githubusercontent.com/114514-homo-lab/V2bX-script/master/initconfig.sh
source initconfig.sh
rm initconfig.sh -f
generate_config_file
read -rp "是否安装bbr内核 ?(y/n): " if_install_bbr
if [[ $if_install_bbr == [Yy] ]]; then
install_bbr
fi
fi
fi
}
echo -e "${green}开始安装${plain}"
install_base
install_V2bX $1