#!/bin/bash # 加载系统函数库(Only for RHEL Linux) # [ -f /etc/init.d/functions ] && source /etc/init.d/functions # 获取脚本工作目录绝对路径 Server_Dir=$(cd $(dirname "${BASH_SOURCE[0]}") && pwd) # 加载.env变量文件 source $Server_Dir/.env Conf_Dir="$Server_Dir/conf" Temp_Dir="$Server_Dir/temp" Log_Dir="$Server_Dir/logs" URL=${CLASH_URL} # 自定义action函数,实现通用action功能 success() { echo -en "\\033[60G[\\033[1;32m OK \\033[0;39m]\r" return 0 } failure() { local rc=$? echo -en "\\033[60G[\\033[1;31mFAILED\\033[0;39m]\r" [ -x /bin/plymouth ] && /bin/plymouth --details return $rc } action() { local STRING rc STRING=$1 echo -n "$STRING " shift "$@" && success $"$STRING" || failure $"$STRING" rc=$? echo return $rc } # 判断命令是否正常执行 函数 if_success() { local ReturnStatus=$3 if [ $ReturnStatus -eq 0 ]; then action "$1" /bin/true else action "$2" /bin/false exit 1 fi } # 临时取消环境变量 unset http_proxy unset https_proxy unset no_proxy # 检查url是否有效 echo -e '\n正在检测订阅地址...' Text1="Clash订阅地址可访问!" Text2="Clash订阅地址不可访问!" for i in {1..10} do curl -o /dev/null -s -m 10 --connect-timeout 10 -w %{http_code} $URL | grep '[23][0-9][0-9]' &>/dev/null ReturnStatus=$? if [ $ReturnStatus -eq 0 ]; then break else continue fi done if_success $Text1 $Text2 $ReturnStatus # 拉取更新config.yml文件 echo -e '\n正在下载Clash配置文件...' Text3="配置文件config.yaml下载成功!" Text4="配置文件config.yaml下载失败,退出启动!" for i in {1..10} do #curl -s -o $Temp_Dir/clash.yaml $URL wget -q --no-check-certificate -O $Temp_Dir/clash.yaml $URL ReturnStatus=$? if [ $ReturnStatus -eq 0 ]; then break else continue fi done if_success $Text3 $Text4 $ReturnStatus # 取出代理相关配置 sed -n '/^proxies:/,$p' $Temp_Dir/clash.yaml > $Temp_Dir/proxy.txt # 合并形成新的config.yaml cat $Temp_Dir/templete_config.yaml > $Temp_Dir/config.yaml cat $Temp_Dir/proxy.txt >> $Temp_Dir/config.yaml \cp $Temp_Dir/config.yaml $Conf_Dir/ # Configure Clash Dashboard Work_Dir=$(cd $(dirname $0); pwd) Dashboard_Dir="${Work_Dir}/dashboard/public" sed -ri "s@^# external-ui:.*@external-ui: ${Dashboard_Dir}@g" $Conf_Dir/config.yaml # 随机生成并更新 API Secret Secret=`openssl rand -hex 32` sed -r -i '/^secret: /s@(secret: ).*@\1'${Secret}'@g' $Conf_Dir/config.yaml # 获取CPU架构 if /bin/arch &>/dev/null; then CpuArch=`/bin/arch` elif /usr/bin/arch &>/dev/null; then CpuArch=`/usr/bin/arch` elif /bin/uname -m &>/dev/null; then CpuArch=`/bin/uname -m` else echo -e "\033[31m\n[ERROR] Failed to obtain CPU architecture!\033[0m" exit 1 fi # 启动Clash服务 echo -e '\n正在启动Clash服务...' Text5="服务启动成功!" Text6="服务启动失败!" if [[ $CpuArch =~ "x86_64" ]]; then nohup $Server_Dir/bin/clash-linux-amd64 -d $Conf_Dir &> $Log_Dir/clash.log & ReturnStatus=$? if_success $Text5 $Text6 $ReturnStatus elif [[ $CpuArch =~ "aarch64" || $CpuArch =~ "arm64" ]]; then nohup $Server_Dir/bin/clash-linux-arm64 -d $Conf_Dir &> $Log_Dir/clash.log & ReturnStatus=$? if_success $Text5 $Text6 $ReturnStatus elif [[ $CpuArch =~ "armv7" ]]; then nohup $Server_Dir/bin/clash-linux-armv7 -d $Conf_Dir &> $Log_Dir/clash.log & ReturnStatus=$? if_success $Text5 $Text6 $ReturnStatus else echo -e "\033[31m\n[ERROR] Unsupported CPU Architecture!\033[0m" exit 1 fi # Output Dashboard access address and Secret echo '' echo -e "Clash Dashboard 访问地址:http://:9090/ui" echo -e "Secret:${Secret}" echo '' # 添加环境变量(root权限) cat>/etc/profile.d/clash.sh<