channeld is an efficient gateway service designed for massive online systems with high fidelity interactions, such as multiplayer games and 3D virtual events. It can be seamlessly integrated with the mainstream game engines (e.g. Unity, Unreal Engine) to develop dedicated servers, together to distributionally simulate the parallel game sessions or seamless open worlds.
channeld是为大型多人交互系统(如MMO,虚拟演唱会)设计的高性能网关服务,可无缝接入UE、Unity等引擎进行专用服务器的开发,用于分布式地模拟多房间及无缝大世界等应用。
See the concepts in the design doc.
There are three major types of application benifit from channeld's architecture design:
channeld的架构设计可应用于以下三种场景:
channeld can be used as the relay server to forward/broadcast messages between game clients.
channeld可用于中继服务器,用于转发/广播游戏客户端之间的消息。
channeld can be used as the gateway server to route messages to different dedicated servers.
channeld可用于专用服务器网关,用于将消息路由到不同的专用服务器。
The ultimate purpose of channeld is to enable distributed composition of dedicated servers, together to form a seamless large virtual world.
channeld的最终目标是实现专用服务器的分布式组合,从而形成无缝的大型虚拟世界。
- Protobuf-based binary protocol over TCP, KCP or WebSocket
- FSM-based message filtering
- Fanout-based data pub/sub of any type defined with Protobuf
- Interest management based on channel and data pub/sub
- Integration with the mainstream game engines (Unity, Unreal Engine)
- [WIP] Backend servers load-balancing with auto-scaling
关键特性:
- 基于Protobuf的二进制协议,支持TCP、KCP、WebSocket
- 基于有限状态机的消息过滤
- 基于扇出的数据发布/订阅,支持任意Protobuf定义的数据类型
- 基于频道和数据发布/订阅的兴趣管理
- 接入主流游戏引擎(Unity, Unreal Engine)
channeld is aimed to support 10K connections and 100K mps(messages per second) on a single node (uplink + downlink), and 10M+ mps in a distributed system.
channeld的目标是在单个节点(上行+下行)上支持10K连接和100K mps(每秒消息数),以及在分布式系统中支持10M+ mps。
There is a dedicated roadmap documentation.
Keep in mind that the requirements of the real-life projects will decide the priority of the development.
路线图详见这里。
请注意,实际项目的需求将决定开发的优先级。
The fastest way to run the server is with Docker Compose.
There's a docker-compose file set up for running the chat rooms demo. Navigate to the root of the repo and run the command:
docker-compose up chat
After starting the server, browse to http://localhost:8080.
Use the input box at the bottom to send messages, to the GLOBAL channel by default. The input box can also be used to send commands, which are started with '/'. The supported commands are:
list [typeFilter] [metadataFilter1],[metadataFilter2],...
// the result format isChannel(<ChannelTypeName> <ChannelId>)
create <channelType> <metadata>
// the channelType is an integer. See the ChannelType enum value defined in the proto fileremove <channelId>
// only the channel creator has the permission to remove the channel.sub <channelId>
// subscribe to the channelunsub <channelId>
// unsubscribe from the channelswitch <channelId>
// switch the active channel. Only the active channel displays the new chat messages.
Follow these steps if the docker image has not been built for the tanks service yet:
- Check out the unity-mirror-channeld repo
- Create the Unity project following the instruction
- Either build the Linux player from Unity Editor (Build -> Linux Server), or via the command:
Unity -batchmode -nographics -projectPath <PATH_TO_YOUR_UNITY_PROJECT> -executeMethod BuildScript.BuildLinuxServer -logFile build.log -quit
. The path to the Unity Editor needs to added to the PATH environment argument in order to run the command. - Build the docker image:
docker build -t channeld/tanks .
Running the Unity tanks demo with Docker is similar to running the chat rooms demo. Navigate to the root of the repo and run the command:
docker-compose up tanks
Then you can the play the game in Unity Editor. See the full instruction here.