refactor(logic): 重构服务器启动逻辑与任务状态管理 - 移除了 `gcmd` 包在 controller 中的直接使用,改为通过参数传递端口和服务器类型 - 统一使用 `GetTask` 和 `SetTask` 方法替代直接访问 `TaskList` 数组,提升代码可维护性 - 修改了战斗逻辑中部分调试打印语句,并优化战斗循环结束日志输出 - 调整了新手玩家初始化流程,默认完成新手任务4 - 更新了数据库模型字段及结构定义,如增加 `max_ts` 字段、扩展 `TaskList` 长度等 - 改进了宠物添加逻辑,采用 SQL 方式确保捕捉时间唯一递增 - 清理了无用或注释掉的旧代码块
84 lines
1.9 KiB
Go
84 lines
1.9 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"runtime"
|
|
"strings"
|
|
|
|
_ "github.com/gogf/gf/contrib/nosql/redis/v2"
|
|
"github.com/gogf/gf/v2/os/gcmd"
|
|
"github.com/gogf/gf/v2/os/gproc"
|
|
|
|
"blazing/logic/service/fight"
|
|
"blazing/logic/service/player"
|
|
|
|
"blazing/cool"
|
|
|
|
//"blazing/o/service"
|
|
"blazing/modules/base/service"
|
|
blservice "blazing/modules/blazing/service"
|
|
"net/http"
|
|
_ "net/http/pprof"
|
|
)
|
|
|
|
func PprofWeb() {
|
|
runtime.SetMutexProfileFraction(1) // (非必需)开启对锁调用的跟踪
|
|
runtime.SetBlockProfileRate(1) // (非必需)开启对阻塞操作的跟踪
|
|
err := http.ListenAndServe(":9909", nil)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
}
|
|
func signalHandlerForMain(sig os.Signal) {
|
|
fight.Fightpool.ReleaseTimeout(0)
|
|
|
|
player.Mainplayer.Range(func(key uint32, value *player.Player) bool {
|
|
value.Save()
|
|
|
|
return true
|
|
})
|
|
fmt.Println("MainProcess is shutting down due to signal:", sig.String())
|
|
}
|
|
|
|
func main() {
|
|
//loadAccounts()
|
|
// if cool.IsRedisMode {
|
|
// go cool.ListenFunc(gctx.New())
|
|
// }
|
|
// 解析命令行参数
|
|
cool.Config.PortBL = gcmd.GetOpt("port", "1").Uint16()
|
|
go Start(cool.Config.PortBL) //注入service
|
|
if cool.Config.PortBL == 1 || cool.Config.PortBL == 2 { //只分析1服务器的
|
|
go PprofWeb()
|
|
}
|
|
|
|
fmt.Println("Process start, pid:", os.Getpid())
|
|
|
|
gproc.AddSigHandlerShutdown(
|
|
|
|
signalHandlerForMain,
|
|
)
|
|
|
|
gproc.Listen()
|
|
}
|
|
|
|
func loadAccounts() {
|
|
t1, _ := os.Getwd()
|
|
data, err := os.ReadFile(t1 + "/b.csv")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
lines := strings.Split(string(data), "\n")
|
|
for _, line := range lines {
|
|
line = strings.TrimSpace(line)
|
|
if line == "" {
|
|
continue
|
|
}
|
|
t := service.NewBaseSysUserService().GetEamil(line)
|
|
|
|
blservice.NewUserService(uint32(t.ID)).Info.Reg(t.Username, 0)
|
|
}
|
|
//fmt.Printf("加载 %d 个账号\n", len(accounts))
|
|
}
|