All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.iohao.game.bolt.broker.server.BrokerServer Maven / Gradle / Ivy

There is a newer version: 21.20
Show newest version
/*
 * ioGame
 * Copyright (C) 2021 - present  渔民小镇 ([email protected][email protected]) . All Rights Reserved.
 * # iohao.com . 渔民小镇
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see .
 */
package com.iohao.game.bolt.broker.server;

import com.alipay.remoting.rpc.RpcConfigs;
import com.alipay.remoting.rpc.RpcServer;
import com.iohao.game.action.skeleton.i18n.Bundle;
import com.iohao.game.action.skeleton.i18n.MessageKey;
import com.iohao.game.action.skeleton.toy.IoGameBanner;
import com.iohao.game.bolt.broker.cluster.BrokerClusterManager;
import com.iohao.game.bolt.broker.cluster.BrokerRunModeEnum;
import com.iohao.game.bolt.broker.core.GroupWith;
import com.iohao.game.bolt.broker.server.balanced.BalancedManager;
import com.iohao.game.bolt.broker.server.service.BrokerClientModules;
import com.iohao.game.common.consts.IoGameLogName;
import com.iohao.game.core.common.cmd.CmdRegions;
import com.iohao.game.core.common.cmd.DefaultCmdRegions;
import lombok.AccessLevel;
import lombok.Getter;
import lombok.Setter;
import lombok.experimental.Accessors;
import lombok.experimental.FieldDefaults;
import lombok.extern.slf4j.Slf4j;

import java.util.Optional;

/**
 * Broker Server (游戏网关服)
 * 
 *     通过 {@link BrokerServerBuilder#build()} 构建游戏网关服
 * 
* * @author 渔民小镇 * @date 2022-05-14 */ @Getter @Accessors(chain = true) @Setter(AccessLevel.PACKAGE) @Slf4j(topic = IoGameLogName.CommonStdout) @FieldDefaults(level = AccessLevel.PRIVATE) public class BrokerServer implements GroupWith { final BalancedManager balancedManager = new BalancedManager(this); final CmdRegions cmdRegions = new DefaultCmdRegions(); /** * brokerId (游戏网关的id),服务器唯一标识 *
     *     如果没设置,会随机分配一个
     *
     *     逻辑服的模块id,标记不同的逻辑服模块。
     *     开发者随意定义,只要确保每个逻辑服的模块 id 不相同就可以
     * 
*/ String brokerId; /** broker 端口(游戏网关端口) */ int port; /** rpc server */ RpcServer rpcServer; /** broker (游戏网关)的启动模式,默认单机模式 */ BrokerRunModeEnum brokerRunMode; /** 集群管理器 */ BrokerClusterManager brokerClusterManager; BrokerClientModules brokerClientModules; int withNo; BrokerServer() { } void initRpcServer() { this.rpcServer = new RpcServer(this.port, true); } public void startup() { IoGameBanner.me().init(); // #100 System.setProperty(RpcConfigs.DISPATCH_MSG_LIST_IN_DEFAULT_EXECUTOR, "false"); // 启动 bolt rpc this.rpcServer.startup(); // 启动集群 Optional.ofNullable(this.brokerClusterManager).ifPresent(BrokerClusterManager::start); extractedLog(); IoGameBanner.render(); IoGameBanner.me().countDown(); } private void extractedLog() { String gameBrokerServer = Bundle.getMessage(MessageKey.gameBrokerServer); String gameBrokerServerStartupMode = Bundle.getMessage(MessageKey.gameBrokerServerStartupMode); log.info("{} port:[{}] - {}:[{}] ", gameBrokerServer, this.port, gameBrokerServerStartupMode, this.brokerRunMode ); } public void shutdown() { this.rpcServer.shutdown(); } public static BrokerServerBuilder newBuilder() { return new BrokerServerBuilder(); } @Override public void setWithNo(int withNo) { this.withNo = withNo; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy