新增 github.com/xiaoqidun/limit 依赖,替换原有的全局速率限制器, 实现针对客户端 IP 的细粒度限流控制。在服务启动时初始化限流器, 并在程序退出前确保后台任务正确停止。同时更新 go.work 和 login/go.sum 文件以包含新的依赖项。此外,在 logic/main.go 中添加了主玩家数据 保存逻辑以确保服务关闭时数据持久化。
71 lines
2.0 KiB
Go
71 lines
2.0 KiB
Go
package cmd
|
|
|
|
import (
|
|
"context"
|
|
"runtime"
|
|
|
|
"blazing/cool"
|
|
|
|
i18n "blazing/modules/base/middleware"
|
|
|
|
"github.com/gogf/gf/v2/frame/g"
|
|
"github.com/gogf/gf/v2/net/ghttp"
|
|
"github.com/gogf/gf/v2/os/gcmd"
|
|
"github.com/gogf/gf/v2/os/gfile"
|
|
"github.com/xiaoqidun/limit"
|
|
"golang.org/x/time/rate"
|
|
)
|
|
|
|
var (
|
|
limiter = limit.New()
|
|
Main = gcmd.Command{
|
|
Name: "main",
|
|
Usage: "main",
|
|
Brief: "start http server",
|
|
Func: func(ctx context.Context, parser *gcmd.Parser) (err error) {
|
|
// g.Dump(g.DB("test").GetConfig())
|
|
if cool.IsRedisMode {
|
|
go cool.ListenFunc(ctx)
|
|
}
|
|
// 1. 创建一个新的 Limiter 实例
|
|
|
|
// 2. 确保在程序退出前优雅地停止后台任务,这非常重要
|
|
defer limiter.Stop()
|
|
s := g.Server()
|
|
s.Use(Limiter, ghttp.MiddlewareHandlerResponse)
|
|
s.EnableAdmin()
|
|
s.SetServerAgent(cool.Config.Name)
|
|
s.BindHookHandler("/*", ghttp.HookBeforeServe, beforeServeHook)
|
|
runtime.SetMutexProfileFraction(1) // (非必需)开启对锁调用的跟踪
|
|
runtime.SetBlockProfileRate(1) // (非必需)开启对阻塞操作的跟踪
|
|
s.EnablePProf()
|
|
// 如果存在 data/cool-admin-vue/dist 目录,则设置为主目录
|
|
if gfile.IsDir("public") {
|
|
s.SetServerRoot("public")
|
|
}
|
|
// i18n 信息
|
|
s.BindHandler("/i18n", i18n.I18nInfo)
|
|
// g.Server().BindMiddleware("/*", MiddlewareCORS)
|
|
s.Run()
|
|
return nil
|
|
},
|
|
}
|
|
)
|
|
|
|
func beforeServeHook(r *ghttp.Request) {
|
|
//glog.Debugf(r.GetCtx(), "beforeServeHook [is file:%v] URI:%s", r.IsFileRequest(), r.RequestURI)
|
|
r.Response.CORSDefault()
|
|
}
|
|
|
|
// Limiter is a middleware that implements rate limiting for all HTTP requests.
|
|
// It returns HTTP 429 (Too Many Requests) when the rate limit is exceeded.
|
|
func Limiter(r *ghttp.Request) {
|
|
rateLimiter := limiter.Get(r.GetClientIp(), rate.Limit(10), 2)
|
|
|
|
if !rateLimiter.Allow() {
|
|
r.Response.WriteStatusExit(429) // Return 429 Too Many Requests
|
|
r.ExitAll()
|
|
}
|
|
r.Middleware.Next()
|
|
}
|