-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreate-vultr-instance.sh
117 lines (89 loc) · 3.59 KB
/
create-vultr-instance.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
#!/bin/bash
# 导入配置文件
source ./conf.env
# 创建临时文件用于存储输出信息
OUTPUT_FILE=$(mktemp)
# 默认值
region=$VULTR_INSTANCE_REGION
xrayschema=tcp
# 解析命令行选项和参数
while [[ "$#" -gt 0 ]]; do
case $1 in
--region) region="$2"; shift ;;
--xrayschema) xrayschema="$2"; shift ;;
*) echo "Unknown parameter passed: $1"; exit 1 ;;
esac
shift # 移动到下一个键值对
done
# DingDing 通知
send_dingtalk_message() {
local message=$1
# 发送POST请求
curl "$DINGTALK_NOTICE_WEBHOOK_URL" \
-H 'Content-Type: application/json' \
-d "{
\"msgtype\": \"text\",
\"text\": {
\"content\": \"$message\"
}
}"
}
# 首先调用 remove-vultr-instance.sh 脚本来删除现有实例
sh /root/vultr/remove-vultr-instance.sh
# 检查上一个命令是否成功执行
if [ $? -ne 0 ]; then
echo "Failed to remove existing instances. Exiting..." | tee -a "$OUTPUT_FILE"
exit 1
fi
# 创建实例并获取ID
echo "Creating Vultr instance..."
CREATE_OUTPUT=$($VULTR_CLI instance create --region $region --plan $VULTR_INSTANCE_PLAN --os $VULTR_INSTANCE_OS_ID --ssh-keys $SSH_KEY_ID)
if [[ $? -ne 0 ]]; then
echo "Failed to create Vultr instance." | tee -a "$OUTPUT_FILE"
exit 1
fi
INSTANCE_ID=$(echo "$CREATE_OUTPUT" | grep 'ID' | awk '{print $2}')
if [[ -z "$INSTANCE_ID" ]]; then
echo "Unable to find Instance ID from creation output." | tee -a "$OUTPUT_FILE"
exit 1
fi
echo "Instance created with ID: $INSTANCE_ID" | tee -a "$OUTPUT_FILE"
# 循环检查实例状态直到它包含 active 并获取MAIN IP地址
while true; do
echo "Checking instance status..."
INSTANCE_INFO=$($VULTR_CLI instance get $INSTANCE_ID)
STATUS=$(echo "$INSTANCE_INFO" | grep -io 'STATUS\s\+active') # 使用正则表达式匹配 STATUS 和 active
if [[ $STATUS ]]; then # 检查是否有匹配
# 使用 awk 正则表达式来匹配 MAIN IP 后跟随的IP地址
MAIN_IP=$(echo "$INSTANCE_INFO" | awk '/MAIN IP/ {for(i=1;i<=NF;i++) if ($i=="IP") print $(i+1)}')
break # 跳出循环当状态包含 active
else
echo "Instance is not active yet. Waiting for 30 seconds..."
sleep 30 # 等待30秒再次检查状态
fi
done
echo "Instance is active with MAIN IP: $MAIN_IP" | tee -a "$OUTPUT_FILE"
echo "Waiting for 2 minute before logging in..."
sleep 120
# SSH 登陆到主机并禁用UFW防火墙 (确保你有权限无密码登陆)
echo "Disabling UFW firewall on the server..."
ssh -o StrictHostKeyChecking=no -i $SSH_KEY_PATH root@$MAIN_IP << EOF
ufw disable
EOF
if [[ $? -eq 0 ]]; then
echo "UFW firewall has been disabled successfully." | tee -a "$OUTPUT_FILE"
else
echo "Failed to disable UFW firewall." | tee -a "$OUTPUT_FILE"
fi
echo "Running install xray script from GitHub..." | tee -a "$OUTPUT_FILE"
INSTALL_OUTPUT=$(ssh -o StrictHostKeyChecking=no -i $SSH_KEY_PATH root@$MAIN_IP 'bash <(wget -qO- -o- https://github.com/233boy/Xray/raw/main/install.sh)')
echo "$INSTALL_OUTPUT" | tee -a "$OUTPUT_FILE"
echo "Running xray to create tcp" | tee -a "$OUTPUT_FILE"
ssh -o StrictHostKeyChecking=no -i $SSH_KEY_PATH root@$MAIN_IP 'xray del' | tee -a "$OUTPUT_FILE"
ssh -o StrictHostKeyChecking=no -i $SSH_KEY_PATH root@$MAIN_IP 'xray add tcp' | tee -a "$OUTPUT_FILE"
# 将临时文件内容读取到变量中,并发送通知消息至钉钉群组机器人
MESSAGE_CONTENT=$(<"$OUTPUT_FILE")
send_dingtalk_message "$MESSAGE_CONTENT"
# 清理:删除临时文件
rm "$OUTPUT_FILE"
exit 0 # 脚本执行成功结束退出码为0.