#!/bin/bash # ========================================================== # 脚本名称: runner.sh (IP-Sentinel 主控调度引擎 - 动态锚点版) # 核心功能: 防并发延迟启动、功能开关(Feature Flag)自适应、多模块概率轮盘调度 # ========================================================== INSTALL_DIR="/opt/ip_sentinel" CONFIG_FILE="${INSTALL_DIR}/config.conf" # 1. 检查并加载本地冷数据配置 if [ ! -f "$CONFIG_FILE" ]; then echo "配置文件丢失,请重新运行 install.sh" exit 1 fi source "$CONFIG_FILE" # ================== [新增: 文件排他锁,防止并发重入引发内存雪崩] ================== exec 200>"/tmp/ip_sentinel_runner.lock" if ! flock -n 200; then echo "[$(date)] ⚠️ 上一轮巡逻任务尚未结束,本次触发自动取消。" >> "$LOG_FILE" exit 0 fi # ================================================================================== # 2. 全局日志写入函数 (导出给子进程共享使用,v3.4.0 引入版本探针) log() { local module=$1 local level=$2 local msg=$3 # [v3.4.0 核心] 提取当前配置中的版本锚点 local local_ver="${AGENT_VERSION:-未知}" mkdir -p "${INSTALL_DIR}/logs" local core_msg=$(printf "[v%-5s] [%-5s] [%-7s] [%s] %s" "$local_ver" "$level" "$module" "$REGION_CODE" "$msg") echo "[$(date '+%Y-%m-%d %H:%M:%S')] $core_msg" >> "$LOG_FILE" if command -v logger >/dev/null 2>&1; then logger -t ip-sentinel "$core_msg" else echo "$core_msg" fi } export -f log export CONFIG_FILE INSTALL_DIR # 3. 防僵尸网络特征 (Cron Jitter) - 核心隐蔽逻辑 # 配合每 30 分钟的调度周期,将随机休眠控制在 0 到 180 秒内,彻底打散全球并发请求 if [ -t 1 ]; then log "SYSTEM" "INFO " "💻 检测到人工终端干预,跳过静默休眠,立即执行任务!" else JITTER_TIME=$((RANDOM % 180)) log "SYSTEM" "INFO " "⏱️ 主控引擎由后台唤醒,进入防并发随机休眠状态: ${JITTER_TIME} 秒..." sleep $JITTER_TIME fi # 4. 唤醒并读取功能开关,执行智能调度 (Feature Flag) log "SYSTEM" "INFO" "休眠结束,开始计算本轮任务轮盘..." TARGET_MOD="" MOD_NAME="" # 智能轮盘赌算法 if [ "$ENABLE_GOOGLE" == "true" ] && [ "$ENABLE_TRUST" == "true" ]; then # 双管齐下: 70% 概率跑 Google 稳固定位,30% 概率跑 Trust 洗刷风控分 ROLL=$((RANDOM % 100 + 1)) if [ $ROLL -le 70 ]; then TARGET_MOD="mod_google.sh" MOD_NAME="Google 区域纠偏" else TARGET_MOD="mod_trust.sh" MOD_NAME="IP 信用净化" fi elif [ "$ENABLE_GOOGLE" == "true" ]; then TARGET_MOD="mod_google.sh" MOD_NAME="Google 区域纠偏" elif [ "$ENABLE_TRUST" == "true" ]; then TARGET_MOD="mod_trust.sh" MOD_NAME="IP 信用净化" else log "SYSTEM" "WARN" "节点未开启任何养护模块,跳过本轮执行。" exit 0 fi # 5. 拉起选定的业务模块 if [ -n "$TARGET_MOD" ] && [ -x "${INSTALL_DIR}/core/${TARGET_MOD}" ]; then log "SYSTEM" "INFO" "命中触发条件,加载并执行子模块: ${MOD_NAME}" # 核心降耗逻辑:使用 nice -n 19 赋予进程最低 CPU 优先级,绝不抢占 VPS 正常业务的资源 nice -n 19 bash "${INSTALL_DIR}/core/${TARGET_MOD}" else log "SYSTEM" "ERROR" "配置了模块 ${MOD_NAME},但未找到对应的可执行脚本: ${TARGET_MOD}" fi log "SYSTEM" "INFO" "本轮所有模块调度完毕,哨兵继续隐蔽待命。"