start-relay.sh 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. #!/usr/bin/env bash
  2. set -euo pipefail
  3. usage() {
  4. cat <<'EOF'
  5. Usage: start-relay.sh <token>
  6. Options via env:
  7. MYNETSPEEDER_RELAY_HOST relay 监听地址,默认 0.0.0.0
  8. MYNETSPEEDER_RELAY_PORT relay 监听端口,默认 9009
  9. MYNETSPEEDER_INSTALL_DIR 安装目录,默认 /opt/mynetspeeder
  10. MYNETSPEEDER_USER 运行用户,默认 mynetspeeder
  11. EOF
  12. }
  13. LISTEN_HOST="${MYNETSPEEDER_RELAY_HOST:-0.0.0.0}"
  14. LISTEN_PORT="${MYNETSPEEDER_RELAY_PORT:-9009}"
  15. TOKEN="${MYNETSPEEDER_RELAY_TOKEN:-${1:-}}"
  16. INSTALL_DIR="${MYNETSPEEDER_INSTALL_DIR:-/opt/mynetspeeder}"
  17. INSTALL_PARENT="$(dirname "$INSTALL_DIR")"
  18. PACKAGE_NAME="$(basename "$INSTALL_DIR")"
  19. RUNTIME_USER="${MYNETSPEEDER_USER:-mynetspeeder}"
  20. PID_FILE="/var/run/mynetspeeder-relay.pid"
  21. LOG_FILE="/var/log/mynetspeeder-relay.log"
  22. LOG_MAX_MB="${MYNETSPEEDER_LOG_MAX_MB:-50}"
  23. LOG_BACKUPS="${MYNETSPEEDER_LOG_BACKUPS:-3}"
  24. if [[ $EUID -ne 0 ]]; then
  25. echo "need root"
  26. exit 1
  27. fi
  28. if [[ -z "$TOKEN" ]]; then
  29. usage
  30. exit 1
  31. fi
  32. if [[ ! -d "$INSTALL_DIR" ]]; then
  33. echo "install dir not found: $INSTALL_DIR"
  34. exit 1
  35. fi
  36. id -u "$RUNTIME_USER" >/dev/null 2>&1 || useradd --system --no-create-home --shell /usr/sbin/nologin "$RUNTIME_USER"
  37. mkdir -p /var/log
  38. touch "$LOG_FILE"
  39. chown "$RUNTIME_USER":"$RUNTIME_USER" "$LOG_FILE"
  40. if ! [[ "$LOG_MAX_MB" =~ ^[0-9]+$ ]] || ! [[ "$LOG_BACKUPS" =~ ^[0-9]+$ ]]; then echo "log limits must be numeric"; exit 1; fi
  41. LOG_MAX_BYTES=$((LOG_MAX_MB * 1024 * 1024))
  42. pkill -f 'python3 -m mynetspeeder relay' || true
  43. runuser -u "$RUNTIME_USER" -- bash -lc "export PYTHONUNBUFFERED=1; export PYTHONPATH=${INSTALL_PARENT}; cd ${INSTALL_PARENT} && exec nohup python3 -m ${PACKAGE_NAME} relay --listen-host ${LISTEN_HOST} --listen-port ${LISTEN_PORT} --token ${TOKEN} 2>&1 | python3 ${INSTALL_DIR}/scripts/rotate-log.py ${LOG_FILE} ${LOG_MAX_BYTES} ${LOG_BACKUPS}" &
  44. RELAY_PID=$!
  45. echo "$RELAY_PID" > "$PID_FILE"
  46. sleep 1
  47. if ! ss -ln | grep -qE "[:.]${LISTEN_PORT}( |$)"; then
  48. echo "relay failed to listen on ${LISTEN_HOST}:${LISTEN_PORT}"
  49. tail -n 50 "$LOG_FILE" || true
  50. exit 1
  51. fi
  52. echo "relay started on ${LISTEN_HOST}:${LISTEN_PORT}"
  53. echo "pid file: $PID_FILE"
  54. echo "log file: $LOG_FILE"
  55. echo "log max: ${LOG_MAX_MB}MB x ${LOG_BACKUPS}"