2025-12-11 10:32:39 +08:00
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
|
"blazing/common/data/xmlres"
|
|
|
|
|
|
"blazing/common/rpc"
|
|
|
|
|
|
"blazing/common/socket"
|
|
|
|
|
|
|
|
|
|
|
|
"blazing/logic/controller"
|
|
|
|
|
|
|
|
|
|
|
|
blservice "blazing/modules/blazing/service"
|
|
|
|
|
|
|
|
|
|
|
|
"fmt"
|
|
|
|
|
|
"log"
|
|
|
|
|
|
"net"
|
|
|
|
|
|
|
|
|
|
|
|
"github.com/gogf/gf/v2/util/gconv"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
const (
|
|
|
|
|
|
minRandomPort = 10000
|
|
|
|
|
|
maxRandomPort = 60000
|
|
|
|
|
|
maxPortRetryCount = 5
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
// determinePort 确定服务器使用的端口
|
2026-01-01 19:57:39 +08:00
|
|
|
|
func determinePort(ports []uint32) (int, error) {
|
2025-12-11 10:32:39 +08:00
|
|
|
|
// 尝试从指定端口列表中找可用端口,最多尝试maxPortRetryCount轮
|
|
|
|
|
|
for i := 0; i < maxPortRetryCount; i++ {
|
|
|
|
|
|
// 遍历指定的端口列表
|
2026-01-01 19:57:39 +08:00
|
|
|
|
for _, port := range ports {
|
2025-12-11 10:32:39 +08:00
|
|
|
|
if isPortAvailable(port) {
|
|
|
|
|
|
return int(port), nil
|
|
|
|
|
|
}
|
|
|
|
|
|
log.Printf("Port %d is not available, checking next...", port)
|
|
|
|
|
|
}
|
|
|
|
|
|
log.Printf("All candidate ports are in use, retrying round %d...", i+1)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return 0, fmt.Errorf("failed to find available port after %d rounds of checking", maxPortRetryCount)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// isPortAvailable 检查端口是否可用
|
2026-01-01 19:57:39 +08:00
|
|
|
|
func isPortAvailable(port uint32) bool {
|
2025-12-11 10:32:39 +08:00
|
|
|
|
address := fmt.Sprintf(":%d", port)
|
|
|
|
|
|
listener, err := net.Listen("tcp", address)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return false
|
|
|
|
|
|
}
|
|
|
|
|
|
defer listener.Close()
|
|
|
|
|
|
return true
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-12-25 12:21:15 +08:00
|
|
|
|
// Start 启动服务器
|
2025-12-11 10:32:39 +08:00
|
|
|
|
// 如果id是0,那就是login server
|
2025-12-25 12:21:15 +08:00
|
|
|
|
func Start(serverID uint16) {
|
2025-12-11 10:32:39 +08:00
|
|
|
|
// 确定端口
|
2026-01-01 19:57:39 +08:00
|
|
|
|
r := blservice.NewLoginServiceService().GetServerID(serverID)
|
|
|
|
|
|
port, err := determinePort(r.CanPort)
|
2025-12-11 10:32:39 +08:00
|
|
|
|
if err != nil {
|
|
|
|
|
|
log.Fatalf("Failed to determine port: %v", err)
|
|
|
|
|
|
}
|
2025-12-25 12:21:15 +08:00
|
|
|
|
server := socket.NewServer(
|
2025-12-11 10:32:39 +08:00
|
|
|
|
socket.WithCORS(),
|
|
|
|
|
|
socket.WithPort(port),
|
|
|
|
|
|
)
|
|
|
|
|
|
// go func() {
|
2025-12-25 12:21:15 +08:00
|
|
|
|
rpcClient := rpc.StartClient(serverID, uint16(port), server)
|
2025-12-11 10:32:39 +08:00
|
|
|
|
|
2026-01-01 19:57:39 +08:00
|
|
|
|
controller.Maincontroller.RPCClient = *rpcClient //将RPC赋值Start
|
|
|
|
|
|
controller.Maincontroller.Port = uint16(port) //赋值服务器ID
|
2025-12-11 10:32:39 +08:00
|
|
|
|
controller.Init(true)
|
|
|
|
|
|
xmlres.Initfile()
|
2025-12-25 12:21:15 +08:00
|
|
|
|
blservice.NewLoginServiceService().SetServerID(serverID, gconv.Uint16(port))
|
|
|
|
|
|
server.Boot()
|
2026-01-01 19:57:39 +08:00
|
|
|
|
}
|