-
Notifications
You must be signed in to change notification settings - Fork 1
/
install.sh
499 lines (406 loc) · 12.6 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
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
#!/bin/bash
#bash <(curl -s -L https://raw.githubusercontent.com/EvilGenius-dot/RMS/main/install.sh)
#bash <(curl -s -L -k https://raw.njuu.cf/EvilGenius-dot/RMS/main/install.sh)
#bash <(curl -s -L -k https://raw.yzuu.cf/EvilGenius-dot/RMS/main/install.sh)
#bash <(curl -s -L -k https://raw.nuaa.cf/EvilGenius-dot/RMS/main/install.sh)
clear
[ $(id -u) != "0" ] && { echo "请使用ROOT用户进行安装, 输入sudo -i切换。"; exit 1; }
IS_OPENWRT=false
# Check for OpenWrt
if [ -f /etc/openwrt_version ]; then
IS_OPENWRT=true
fi
if [ "$IS_OPENWRT" = true ]; then
echo "This is an OpenWrt system."
else
if command -v systemctl &> /dev/null; then
echo "check systemctl..."
clear
else
echo "当前系统不支持systemctl服务, 请先安装systemctl."
exit 1;
fi
fi
SERVICE_NAME="rmservice"
PATH_RMS="/root/rms"
PATH_EXEC="rms"
PATH_NOHUP="${PATH_RMS}/nohup.out"
PATH_ERR="${PATH_RMS}/err.log"
ROUTE_1="https://github.com"
ROUTE_2="http://rustminersystem.com"
# ROUTE_2="https://hub.njuu.cf"
# ROUTE_3="https://hub.yzuu.cf"
# ROUTE_4="https://hub.nuaa.cf"
ROUTE_EXEC_1="/EvilGenius-dot/RMS/raw/main/x86_64-musl/rms"
ROUTE_EXEC_2="/EvilGenius-dot/RMS/raw/main/x86_64-android/rms"
ROUTE_EXEC_3="/EvilGenius-dot/RMS/raw/main/arm-musleabi/rms"
ROUTE_EXEC_4="/EvilGenius-dot/RMS/raw/main/arm-musleabihf/rms"
ROUTE_EXEC_5="/EvilGenius-dot/RMS/raw/main/armv7-musleabi/rms"
ROUTE_EXEC_6="/EvilGenius-dot/RMS/raw/main/armv7-musleabihf/rms"
ROUTE_EXEC_7="/EvilGenius-dot/RMS/raw/main/i586-musl/rms"
ROUTE_EXEC_8="/EvilGenius-dot/RMS/raw/main/i686-android/rms"
ROUTE_EXEC_9="/EvilGenius-dot/RMS/raw/main/aarch64-musl/rms"
TARGET_ROUTE=""
TARGET_ROUTE_EXEC=""
UNAME=`uname -m`
filterResult() {
if [ $1 -eq 0 ]; then
echo ""
else
echo "!!!!!!!!!!!!!!!ERROR!!!!!!!!!!!!!!!!"
echo "【${2}】失败。"
if [ ! $3 ];then
echo "!!!!!!!!!!!!!!!ERROR!!!!!!!!!!!!!!!!"
exit 1
fi
fi
echo -e
}
disable_firewall() {
os_name=$(grep "^ID=" /etc/os-release | cut -d "=" -f 2 | tr -d '"')
echo "关闭防火墙"
if [ "$os_name" == "ubuntu" ]; then
sudo ufw disable
elif [ "$os_name" == "centos" ]; then
sudo systemctl stop firewalld
sudo systemctl disable firewalld
else
echo "未知的操作系统, 关闭防火墙失败"
fi
}
check_process() {
if [ "$IS_OPENWRT" = true ]; then
if pgrep -f "$1" >/dev/null; then
return 0
else
return 1
fi
else
if [[ $(uname) == "Linux" ]]; then
if pgrep -x "$1" >/dev/null; then
return 0
else
return 1
fi
else
if ps aux | grep -v grep | grep "$1" >/dev/null; then
return 0
else
return 1
fi
fi
fi
}
# openwrt设置开机启动
#!/bin/sh
# Function to set up auto-start and start the program
wrt_enable_autostart() {
echo "wrt_set_start"
if [ ! -f /etc/init.d/rms ]; then
# Create an init script for the "rms" service
echo "#!/bin/sh /etc/rc.common" > /etc/init.d/rms
echo "USE_PROCD=1" >> /etc/init.d/rms
echo "START=99" >> /etc/init.d/rms
echo "start() {" >> /etc/init.d/rms
echo " /root/rms/rms &" >> /etc/init.d/rms
echo "}" >> /etc/init.d/rms
echo "PROG=/root/rms/rms" >> /etc/init.d/rms
echo "start_service(){" >> /etc/init.d/rms
echo " procd_open_instance" >> /etc/init.d/rms
echo " procd_set_param command \$PROG" >> /etc/init.d/rms
echo " procd_set_param respawn" >> /etc/init.d/rms
echo " procd_close_instance" >> /etc/init.d/rms
echo "}" >> /etc/init.d/rms
chmod +x /etc/init.d/rms
fi
/etc/init.d/rms enable
/etc/init.d/rms start
}
# Function to stop auto-start and stop the program
wrt_disable_autostart() {
echo "wrt_set_disable"
if [ -f /etc/init.d/rms ]; then
# Stop the "rms" service
/etc/init.d/rms stop
# Remove the init script
rm /etc/init.d/rms
fi
}
# 设置开机启动且进程守护
enable_autostart() {
echo "${m_14}"
if [ "$(command -v systemctl)" ]; then
sudo tee /etc/systemd/system/$SERVICE_NAME.service > /dev/null <<EOF
[Unit]
Description=My Program
After=network.target
[Service]
Type=simple
ExecStart=$PATH_RMS/$PATH_EXEC
WorkingDirectory=$PATH_RMS/
Restart=always
StandardOutput=file:$PATH_RMS/nohup.out
StandardError=file:$PATH_RMS/err.log
TimeoutStopSec=5
[Install]
WantedBy=multi-user.target
EOF
sudo systemctl daemon-reload
sudo systemctl enable $SERVICE_NAME.service
sudo systemctl start $SERVICE_NAME.service
else
sudo sh -c "echo '${PATH_RMS}/${PATH_EXEC} &' >> /etc/rc.local"
sudo chmod +x /etc/rc.local
fi
}
# 禁用开机启动函数
disable_autostart() {
echo "关闭开机启动..."
if [ "$(command -v systemctl)" ]; then
sudo systemctl stop $SERVICE_NAME.service
sudo systemctl disable $SERVICE_NAME.service
sudo rm /etc/systemd/system/$SERVICE_NAME.service
sudo systemctl daemon-reload
else # 系统使用的是SysVinit
sudo sed -i '/\/root\/rustminersystem\/rustminersystem\ &/d' /etc/rc.local
fi
sleep 1
}
kill_process() {
if [ "$IS_OPENWRT" = true ]; then
local process_name="$1"
local pids=($(pgrep -f "$process_name"))
echo "WRT KILL IPD $pids"
if kill -9 "$pids" >/dev/null 2>&1; then
echo "已终止 $pids 进程."
else
echo "未发现 $pids 进程."
return 1
fi
else
local process_name="$1"
local pids=($(pgrep "$process_name"))
if [ ${#pids[@]} -eq 0 ]; then
echo "未发现 $process_name 进程."
return 1
fi
for pid in "${pids[@]}"; do
echo "Stopping process $pid ..."
kill -TERM "$pid"
done
echo "终止 $process_name ."
fi
sleep 1
}
change_limit() {
echo "${m_18}"
changeLimit="n"
if [[ -f /etc/debian_version ]]; then
echo "soft nofile 65535" | sudo tee -a /etc/security/limits.conf
echo "hard nofile 65535" | sudo tee -a /etc/security/limits.conf
echo "fs.file-max = 100000" | sudo tee -a /etc/sysctl.conf
sudo sysctl -p
# add PAM configuration to enable the limits for login sessions
if [[ -f /etc/pam.d/common-session ]]; then
grep -q '^session.*pam_limits.so$' /etc/pam.d/common-session || sudo sh -c "echo 'session required pam_limits.so' >> /etc/pam.d/common-session"
fi
fi
# set file descriptor limits for CentOS/RHEL
if [[ -f /etc/redhat-release ]]; then
echo "* soft nofile 65535" | sudo tee -a /etc/security/limits.conf
echo "* hard nofile 65535" | sudo tee -a /etc/security/limits.conf
echo "fs.file-max = 100000" | sudo tee -a /etc/sysctl.conf
sudo sysctl -p
fi
# set file descriptor limits for macOS
if [[ "$(uname)" == "Darwin" ]]; then
sudo launchctl limit maxfiles 65535 65535
sudo sysctl -w kern.maxfiles=100000
sudo sysctl -w kern.maxfilesperproc=65535
fi
# set systemd file descriptor limits
if [[ -x /bin/systemctl ]]; then
echo "DefaultLimitNOFILE=65535" >>/etc/systemd/user.conf
echo "DefaultLimitNOFILE=65535" >>/etc/systemd/system.conf
systemctl daemon-reexec
fi
if [ $(grep -c "root soft nofile" /etc/security/limits.conf) -eq '0' ]; then
echo "root soft nofile 65535" >>/etc/security/limits.conf
echo "* soft nofile 65535" >>/etc/security/limits.conf
changeLimit="y"
fi
if [ $(grep -c "root hard nofile" /etc/security/limits.conf) -eq '0' ]; then
echo "root hard nofile 65535" >>/etc/security/limits.conf
echo "* hard nofile 65535" >>/etc/security/limits.conf
changeLimit="y"
fi
if [ $(grep -c "DefaultLimitNOFILE=65535" /etc/systemd/user.conf) -eq '0' ]; then
echo "DefaultLimitNOFILE=65535" >>/etc/systemd/user.conf
changeLimit="y"
fi
if [ $(grep -c "DefaultLimitNOFILE=65535" /etc/systemd/system.conf) -eq '0' ]; then
echo "DefaultLimitNOFILE=65535" >>/etc/systemd/system.conf
changeLimit="y"
fi
if [[ "$changeLimit" = "y" ]]; then
echo "连接数限制已修改为65535,重启服务器后生效"
else
echo -n "当前连接数限制:"
ulimit -n
fi
echo "修改完成, 重启服务器后生效"
}
install() {
if [ -f /etc/centos-release ] || \
([ -f /etc/lsb-release ] && . /etc/lsb-release && [ "$DISTRIB_ID" = "Ubuntu" ]) || \
[ -f /etc/openwrt_version ]; then
echo "CENTOS || UBUNTU || OPENWRT"
else
# 在其他操作系统上运行所需的命令
chown root:root /mnt -R
chown root:root /etc -R
chown root:root /usr -R
chown man:root /var/cache/man -R
chmod g+s /var/cache/man -R
fi
disable_firewall
check_process $PATH_EXEC
if [ $? -eq 0 ]; then
echo "发现正在运行的${PATH_EXEC}需要停止才可继续安装。"
echo "输入1停止正在运行的${PATH_EXEC}并且继续安装, 输入2取消安装。"
read -p "$(echo -e "请选择[1-2]:")" choose
case $choose in
1)
stop
;;
2)
echo "取消安装"
return
;;
*)
echo "输入错误, 取消安装。"
return
;;
esac
fi
if [[ ! -d $PATH_RMS ]];then
mkdir $PATH_RMS
chmod 777 -R $PATH_RMS
else
echo "目录已存在, 无需重复创建, 继续执行安装。"
fi
if [[ ! -d $PATH_NOHUP ]];then
touch $PATH_NOHUP
touch $PATH_ERR
chmod 777 -R $PATH_NOHUP
chmod 777 -R $PATH_ERR
fi
echo "开始下载程序..."
wget -P $PATH_RMS "${TARGET_ROUTE}${TARGET_ROUTE_EXEC}" -O "${PATH_RMS}/${PATH_EXEC}" 1>/dev/null
filterResult $? "下载程序"
chmod 777 -R "${PATH_RMS}/${PATH_EXEC}"
change_limit
start
}
restart() {
stop
start
}
uninstall() {
stop
rm -rf ${PATH_RMS}
if [ "$IS_OPENWRT" = true ]; then
wrt_disable_autostart
else
disable_autostart
fi
echo "卸载成功"
}
start() {
echo $BLUE "启动程序..."
check_process $PATH_EXEC
if [ $? -eq 0 ]; then
echo "程序已经启动,请不要重复启动。"
return
else
# cd $PATH_RUST
# nohup "${PATH_RUST}/${PATH_EXEC}" 2>$PATH_ERR &
if [ "$IS_OPENWRT" = true ]; then
wrt_enable_autostart
else
enable_autostart
fi
sleep 1
check_process $PATH_EXEC
if [ $? -eq 0 ]; then
echo "|----------------------------------------------------------------|"
echo "程序启动成功, 访问此地址: 局域网IP:42703"
echo "|----------------------------------------------------------------|"
else
echo "程序启动失败!!!"
fi
fi
}
stop() {
sleep 1
if [ "$IS_OPENWRT" = true ]; then
wrt_disable_autostart
else
disable_autostart
fi
sleep 1
echo "终止进程..."
kill_process $PATH_EXEC
sleep 1
}
echo "------RMS Linux------"
echo "1. 安装"
echo "2. 停止运行RMS"
echo "3. 重启RMS"
echo "4. 卸载RMS"
echo "---------------------"
read -p "$(echo -e "[1-4]:")" comm
if [ "$comm" = "1" ]; then
clear
elif [ "$comm" = "2" ]; then
stop
exit 1
elif [ "$comm" = "3" ]; then
restart
exit 1
elif [ "$comm" = "4" ]; then
uninstall
exit 1
fi
echo "------RMS Linux------"
echo "当前CPU架构【${UNAME}】"
echo 请选择对应架构安装选项。
echo "---------------------"
echo "1. x86-64"
echo "2. x86-64-android"
echo "3. arm-musleabi"
echo "4. arm-musleabihf"
echo "5. armv7-musleabi"
echo "6. armv7-musleabihf"
echo "7. i586"
echo "8. i686-android"
echo "9. aarch64"
echo ""
read -p "$(echo -e "[1-9]:")" targetExec
VARNAME="ROUTE_EXEC_${targetExec}"
TARGET_ROUTE_EXEC="${!VARNAME}"
clear
echo "------RMS Linux------"
echo "请选择下载线路:"
echo "1. 线路1(github官方地址, 如无法下载请选择其他线路)"
echo "2. 线路2"
# echo "3. 线路3"
# echo "4. 线路4"
echo "---------------------"
read -p "$(echo -e "[1-2]:")" targetRoute
VARNAME="ROUTE_${targetRoute}"
TARGET_ROUTE="${!VARNAME}"
[ ! $TARGET_ROUTE ] && { echo "错误的线路选择命令"; exit 1; }
[ ! $TARGET_ROUTE_EXEC ] && { echo "错误的架构选择命令"; exit 1; }
echo "${TARGET_ROUTE}${TARGET_ROUTE_EXEC}"
install