feat(config): 添加服务器调试模式配置和塔配置重构 - 在ServerList结构体中添加IsDebug字段用于调试模式标识 - 修改GetServerInfoList函数增加isdebug参数支持 - 移除硬编码的rpcaddr本地地址配置 - 重构塔配置模型,将tower_500和tower_600合并到tower_110
125 lines
3.1 KiB
Go
125 lines
3.1 KiB
Go
package rpc
|
|
|
|
import (
|
|
"blazing/common/data/share"
|
|
"blazing/cool"
|
|
|
|
"blazing/modules/base/service"
|
|
"context"
|
|
"fmt"
|
|
"log"
|
|
"net/http"
|
|
|
|
blservice "blazing/modules/blazing/service"
|
|
|
|
"github.com/filecoin-project/go-jsonrpc"
|
|
"github.com/gogf/gf/v2/util/gconv"
|
|
)
|
|
|
|
var rpcport = gconv.String(cool.Config.RPC)
|
|
|
|
// Define the server handler
|
|
type ServerHandler struct{}
|
|
|
|
// 实现踢人
|
|
func (h *ServerHandler) Kick(ctx context.Context, userid uint32) error {
|
|
|
|
cool.Logger.Info(context.TODO(), "服务器收到踢人")
|
|
useid1, err := share.ShareManager.GetUserOnline(userid)
|
|
|
|
if err != nil {
|
|
return fmt.Errorf("user not found", err)
|
|
}
|
|
|
|
cl, ok := cool.GetClient(useid1)
|
|
if ok {
|
|
err := cl.KickPerson(userid) //实现指定服务器踢人
|
|
if err != nil {
|
|
return fmt.Errorf("踢人失败", err)
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// 注册logic服务器
|
|
func (h *ServerHandler) RegisterLogic(ctx context.Context, id, port uint16) error {
|
|
cool.Logger.Debug(context.Background(), "注册logic服务器", id, port)
|
|
|
|
//TODO 待修复滚动更新可能导致的玩家可以同时在旧服务器和新服务器同时在线的bug
|
|
revClient, ok := jsonrpc.ExtractReverseClient[cool.ClientHandler](ctx)
|
|
if !ok {
|
|
return fmt.Errorf("no reverse client")
|
|
}
|
|
t := blservice.NewLoginServiceService().GetServerID(id)
|
|
|
|
aa, ok := cool.GetClient(t.Port)
|
|
if ok && aa != nil { //如果已经存在且这个端口已经被存过
|
|
aa.QuitSelf(0)
|
|
}
|
|
cool.AddClient(port, &revClient)
|
|
|
|
//Refurh()
|
|
return nil
|
|
|
|
}
|
|
|
|
func StartServer() {
|
|
// create a new server instance
|
|
rpcServer := jsonrpc.NewServer(jsonrpc.WithReverseClient[cool.ClientHandler](""))
|
|
|
|
rpcServer.Register("", &ServerHandler{})
|
|
cool.Logger.Debug(context.Background(), "jsonrpc server start", rpcport)
|
|
// go time.AfterFunc(3000, func() {
|
|
// testjsonrpc()
|
|
// })
|
|
|
|
err := http.ListenAndServe("0.0.0.0:"+rpcport, rpcServer)
|
|
cool.Logger.Debug(context.Background(), "jsonrpc server fail", err)
|
|
}
|
|
|
|
var closer jsonrpc.ClientCloser
|
|
|
|
func StartClient(id, port uint16, callback any) *struct {
|
|
Kick func(uint32) error
|
|
|
|
RegisterLogic func(uint16, uint16) error
|
|
} {
|
|
|
|
var rpcaddr, _ = service.NewBaseSysParamService().DataByKey(context.Background(), "server_ip")
|
|
//rpcaddr = "127.0.0.1"
|
|
closer1, err := jsonrpc.NewMergeClient(context.Background(),
|
|
"ws://"+rpcaddr+":"+rpcport, "", []interface{}{
|
|
&RPCClient,
|
|
}, nil, jsonrpc.WithClientHandler("", callback),
|
|
jsonrpc.WithReconnFun(func() { RPCClient.RegisterLogic(id, port) }),
|
|
)
|
|
if err != nil {
|
|
log.Fatalf("Failed to create client: %v", err)
|
|
}
|
|
|
|
//if port != 0 { //注册logic
|
|
RPCClient.RegisterLogic(id, port)
|
|
|
|
//}
|
|
|
|
closer = closer1
|
|
return &RPCClient
|
|
}
|
|
|
|
// 关闭客户端
|
|
func CloseClient() {
|
|
if closer != nil {
|
|
closer()
|
|
}
|
|
}
|
|
|
|
// Setup RPCClient with reverse call handler
|
|
var RPCClient struct {
|
|
Kick func(uint32) error //踢人
|
|
|
|
RegisterLogic func(uint16, uint16) error
|
|
|
|
// UserLogin func(int32, int32) error //用户登录事件
|
|
// UserLogout func(int32, int32) error //用户登出事件
|
|
}
|