新增适配hy2后端的v2b的后端脚本
This commit is contained in:
parent
5b7a0bb12f
commit
602f47fbbe
136
vpn/set_hy2_backend/add_hy2_backend.sh
Normal file
136
vpn/set_hy2_backend/add_hy2_backend.sh
Normal file
@ -0,0 +1,136 @@
|
||||
#!/bin/bash
|
||||
|
||||
# 检查是否提供了必要的参数
|
||||
if [ -z "$1" ] || [ -z "$2" ] || [ -z "$3" ] || [ -z "$4" ] || [ -z "$5" ] || [ -z "$6" ] || [ -z "$7" ]; then
|
||||
echo "Usage: $0 --doname <DONAME> --cfemail <CF_Email> --cfken <CF_Key> --apihost <API_HOST> --apikey <API_KEY> --nodeid <NODE_ID> --nodeport <NODE_PORT>"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 解析命令行参数
|
||||
while [[ $# -gt 0 ]]; do
|
||||
case $1 in
|
||||
--doname)
|
||||
DONAME="$2"
|
||||
shift 2
|
||||
;;
|
||||
--cfemail)
|
||||
CF_Email="$2"
|
||||
shift 2
|
||||
;;
|
||||
--cfken)
|
||||
CF_Key="$2"
|
||||
shift 2
|
||||
;;
|
||||
--apihost)
|
||||
API_HOST="$2"
|
||||
shift 2
|
||||
;;
|
||||
--apikey)
|
||||
API_KEY="$2"
|
||||
shift 2
|
||||
;;
|
||||
--nodeid)
|
||||
NODE_ID="$2"
|
||||
shift 2
|
||||
;;
|
||||
--nodeport)
|
||||
NODE_PORT="$2"
|
||||
shift 2
|
||||
;;
|
||||
*)
|
||||
echo "Unknown parameter: $1"
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
# 更新系统并安装必要的软件包
|
||||
sudo apt update && sudo apt upgrade -y && sudo apt install vim wget curl net-tools socat -y
|
||||
|
||||
# 设置主机名
|
||||
sudo hostnamectl set-hostname "$DONAME"
|
||||
|
||||
# 运行acme脚本安装acme
|
||||
curl https://get.acme.sh | sh -s email="$DONAME@randallanjie.com"
|
||||
|
||||
# 添加或更新环境变量到.acme.sh/acme.sh.env文件
|
||||
ENV_FILE="$HOME/.acme.sh/acme.sh.env"
|
||||
grep -q '^export CF_Key=' $ENV_FILE && sed -i "s/^export CF_Key=.*/export CF_Key=\"$CF_Key\"/" $ENV_FILE || echo "export CF_Key=\"$CF_Key\"" >> $ENV_FILE
|
||||
grep -q '^export CF_Email=' $ENV_FILE && sed -i "s/^export CF_Email=.*/export CF_Email=\"$CF_Email\"/" $ENV_FILE || echo "export CF_Email=\"$CF_Email\"" >> $ENV_FILE
|
||||
|
||||
# 直接导出环境变量到当前会话
|
||||
export CF_Key="$CF_Key"
|
||||
export CF_Email="$CF_Email"
|
||||
|
||||
# 设置acme并申请证书
|
||||
~/.acme.sh/acme.sh --upgrade --auto-upgrade
|
||||
~/.acme.sh/acme.sh --set-default-ca --server letsencrypt
|
||||
~/.acme.sh/acme.sh --issue -d "$DONAME" --dns dns_cf --dnssleep
|
||||
|
||||
# 创建必要的目录
|
||||
sudo mkdir -p /etc/hysteria/cert
|
||||
|
||||
# 安装证书
|
||||
~/.acme.sh/acme.sh --installcert -d "$DONAME" --key-file /etc/hysteria/cert/cert.key --fullchain-file /etc/hysteria/cert/fullchain.cer
|
||||
|
||||
# 创建server.yaml配置文件
|
||||
sudo tee /etc/hysteria/server.yaml > /dev/null << EOF
|
||||
v2board:
|
||||
apiHost: $API_HOST
|
||||
apiKey: $API_KEY
|
||||
nodeID: $NODE_ID
|
||||
tls:
|
||||
type: tls
|
||||
cert: /etc/hysteria/cert/fullchain.cer
|
||||
key: /etc/hysteria/cert/cert.key
|
||||
auth:
|
||||
type: v2board
|
||||
trafficStats:
|
||||
listen: 0.0.0.0:$NODE_PORT
|
||||
acl:
|
||||
inline:
|
||||
- reject(10.0.0.0/8)
|
||||
- reject(172.16.0.0/12)
|
||||
- reject(192.168.0.0/16)
|
||||
- reject(127.0.0.0/8)
|
||||
- reject(fc00::/7)
|
||||
EOF
|
||||
|
||||
# 检测系统架构
|
||||
ARCH=$(uname -m)
|
||||
if [ "$ARCH" = "x86_64" ]; then
|
||||
HYSTERIA_URL="https://github.com/cedar2025/hysteria/releases/download/app%2Fv1.0.3/hysteria-linux-amd64"
|
||||
elif [ "$ARCH" = "aarch64" ]; then
|
||||
HYSTERIA_URL="https://github.com/cedar2025/hysteria/releases/download/app%2Fv1.0.3/hysteria-linux-arm64"
|
||||
else
|
||||
echo "Unsupported architecture: $ARCH"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 下载hysteria
|
||||
sudo wget -O /etc/hysteria/hysteriabackend "$HYSTERIA_URL"
|
||||
sudo chmod +x /etc/hysteria/hysteriabackend
|
||||
|
||||
# 创建systemd服务文件
|
||||
sudo tee /lib/systemd/system/hy2backend.service > /dev/null << EOF
|
||||
[Unit]
|
||||
Description = v2board hy2 backend
|
||||
After = network.target syslog.target
|
||||
Wants = network.target
|
||||
|
||||
[Service]
|
||||
Type = simple
|
||||
WorkingDirectory = /etc/hysteria/
|
||||
ExecStart = /etc/hysteria/hysteriabackend server -c /etc/hysteria/server.yaml
|
||||
|
||||
[Install]
|
||||
WantedBy = multi-user.target
|
||||
EOF
|
||||
|
||||
# 重新加载systemd并启动服务
|
||||
sudo systemctl daemon-reload
|
||||
sudo systemctl enable hy2backend
|
||||
sudo systemctl start hy2backend
|
||||
|
||||
echo "Setup complete for $DONAME"
|
||||
|
Loading…
x
Reference in New Issue
Block a user