Files
junhong_cmp_fiber/internal/routes/polling_monitoring.go
huang 931e140e8e
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 6m35s
feat: 实现 IoT 卡轮询系统(支持千万级卡规模)
实现功能:
- 实名状态检查轮询(可配置间隔)
- 卡流量检查轮询(支持跨月流量追踪)
- 套餐检查与超额自动停机
- 分布式并发控制(Redis 信号量)
- 手动触发轮询(单卡/批量/条件筛选)
- 数据清理配置与执行
- 告警规则与历史记录
- 实时监控统计(队列/性能/并发)

性能优化:
- Redis 缓存卡信息,减少 DB 查询
- Pipeline 批量写入 Redis
- 异步流量记录写入
- 渐进式初始化(10万卡/批)

压测工具(scripts/benchmark/):
- Mock Gateway 模拟上游服务
- 测试卡生成器
- 配置初始化脚本
- 实时监控脚本

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-05 17:32:44 +08:00

48 lines
1.5 KiB
Go

package routes
import (
"github.com/gofiber/fiber/v2"
"github.com/break/junhong_cmp_fiber/internal/handler/admin"
"github.com/break/junhong_cmp_fiber/internal/model/dto"
"github.com/break/junhong_cmp_fiber/pkg/openapi"
)
// registerPollingMonitoringRoutes 注册轮询监控路由
func registerPollingMonitoringRoutes(router fiber.Router, handler *admin.PollingMonitoringHandler, doc *openapi.Generator, basePath string) {
stats := router.Group("/polling-stats")
groupPath := basePath + "/polling-stats"
Register(stats, doc, groupPath, "GET", "", handler.GetOverview, RouteSpec{
Summary: "获取轮询总览统计",
Tags: []string{"轮询管理-监控"},
Input: nil,
Output: new(dto.PollingOverviewResp),
Auth: true,
})
Register(stats, doc, groupPath, "GET", "/queues", handler.GetQueueStatuses, RouteSpec{
Summary: "获取轮询队列状态",
Tags: []string{"轮询管理-监控"},
Input: nil,
Output: new(dto.PollingQueueStatusListResp),
Auth: true,
})
Register(stats, doc, groupPath, "GET", "/tasks", handler.GetTaskStatuses, RouteSpec{
Summary: "获取轮询任务统计",
Tags: []string{"轮询管理-监控"},
Input: nil,
Output: new(dto.PollingTaskStatsListResp),
Auth: true,
})
Register(stats, doc, groupPath, "GET", "/init-progress", handler.GetInitProgress, RouteSpec{
Summary: "获取轮询初始化进度",
Tags: []string{"轮询管理-监控"},
Input: nil,
Output: new(dto.PollingInitProgressResp),
Auth: true,
})
}