- Timezone: compute_next_run now correctly interprets cron in the schedule's configured timezone (e.g., "0 8 * * *" with Asia/Shanghai = 8AM Beijing, not UTC) - Notifications: agent_tasks now reuses pre-created execution records and calls notify_schedule_result on completion, so non-workflow agent schedules get DB notifications + Feishu webhook + Feishu app messages - Duplicate execution: execute_agent_task accepts optional execution_id to reuse the record created by schedule_service instead of creating a second one - Celery Beat: added to restart_backend_celery.ps1, stop_aiagent.ps1, and docker-compose.dev.yml; fixed repo-root path resolution in all PS1 scripts Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
74 lines
2.6 KiB
PowerShell
74 lines
2.6 KiB
PowerShell
# Restart backend API (uvicorn) + Celery worker + Celery Beat (scheduler)
|
|
# Does not stop frontend/Redis.
|
|
$ErrorActionPreference = "Continue"
|
|
# Repo root = two levels up from scripts/startup/
|
|
$ScriptDir = Split-Path -Parent $MyInvocation.MyCommand.Path
|
|
$RepoRoot = Split-Path -Parent (Split-Path -Parent $ScriptDir)
|
|
$Backend = Join-Path $RepoRoot "backend"
|
|
$ApiPort = 8037
|
|
|
|
Write-Host "== Stop API + Celery worker + Celery Beat ==" -ForegroundColor Cyan
|
|
|
|
function Stop-ByCommandLine([string]$pattern, [string]$name) {
|
|
$targets = Get-CimInstance Win32_Process | Where-Object {
|
|
$_.CommandLine -and $_.CommandLine -match $pattern
|
|
}
|
|
if (-not $targets) {
|
|
Write-Host "[SKIP] ${name}: no matching process" -ForegroundColor DarkGray
|
|
return
|
|
}
|
|
foreach ($p in $targets) {
|
|
try {
|
|
Stop-Process -Id $p.ProcessId -Force
|
|
Write-Host "[OK] stopped ${name} PID=$($p.ProcessId)" -ForegroundColor Green
|
|
} catch {
|
|
Write-Host "[WARN] failed to stop ${name} PID=$($p.ProcessId)" -ForegroundColor Yellow
|
|
}
|
|
}
|
|
}
|
|
|
|
Stop-ByCommandLine "uvicorn\s+app\.main:app" "backend-api"
|
|
Stop-ByCommandLine "celery\s+-A\s+app\.core\.celery_app\s+worker" "celery-worker"
|
|
Stop-ByCommandLine "celery\s+-A\s+app\.core\.celery_app\s+beat" "celery-beat"
|
|
|
|
Start-Sleep -Seconds 2
|
|
|
|
Write-Host "== Start API on $ApiPort + Celery worker + Celery Beat ==" -ForegroundColor Cyan
|
|
|
|
# 1. API (uvicorn)
|
|
Start-Process powershell -ArgumentList @(
|
|
"-NoExit",
|
|
"-NoProfile",
|
|
"-ExecutionPolicy", "Bypass",
|
|
"-Command",
|
|
"Set-Location '$Backend'; .\venv\Scripts\Activate.ps1; python -m uvicorn app.main:app --host 0.0.0.0 --port $ApiPort"
|
|
)
|
|
|
|
# 2. Celery worker
|
|
Start-Process powershell -ArgumentList @(
|
|
"-NoExit",
|
|
"-NoProfile",
|
|
"-ExecutionPolicy", "Bypass",
|
|
"-Command",
|
|
"Set-Location '$Backend'; .\venv\Scripts\Activate.ps1; python -m celery -A app.core.celery_app worker --loglevel=info --pool=threads --concurrency=8"
|
|
)
|
|
|
|
# 3. Celery Beat (scheduler — 每分钟检查到期的定时任务)
|
|
Start-Process powershell -ArgumentList @(
|
|
"-NoExit",
|
|
"-NoProfile",
|
|
"-ExecutionPolicy", "Bypass",
|
|
"-Command",
|
|
"Set-Location '$Backend'; .\venv\Scripts\Activate.ps1; python -m celery -A app.core.celery_app beat --loglevel=info"
|
|
)
|
|
|
|
Write-Host ""
|
|
Write-Host "[DONE] 已在新窗口启动 API + Celery Worker + Celery Beat" -ForegroundColor Green
|
|
Write-Host "API: http://127.0.0.1:$ApiPort/docs" -ForegroundColor Cyan
|
|
Write-Host "Celery Beat 负责每分钟检查定时任务,如果定时推送没触发,请确认 Beat 窗口正在运行" -ForegroundColor Yellow
|
|
|
|
Start-Sleep -Seconds 2
|
|
Write-Host ""
|
|
Write-Host "Port $ApiPort :" -ForegroundColor Cyan
|
|
netstat -ano | findstr ":$ApiPort"
|