/century

Golang game server for 21st Century (prototype)

Primary LanguageGoBSD 2-Clause "Simplified" LicenseBSD-2-Clause

Century

Golang game server for 21st Century (prototype)

Description

It's just a skeleton of what I call "Next-generation game server". But it's a runnable prototype, with basic error handlings, and benchmarkable performance maturity.

I started with a chat application scenario, but you can simply modify it to match the need of any realtime game server, or even general realtime server, just by replacing the "broadcast" method with your own "ProcessPacket" method.

It's both simple enough and complete enough to demonstrate the next-generation network programs, which are expected to have at least the features of --

Feature

  • High throughput
  • High concurrency
  • (Automatic) High scalability, especially on many-core computers. (Think of 64-core computers, as much as 4-core ones.)

Detailed Information

You can find an even simpler chat server on:

https://gist.github.com/drewolson/3950226

(In fact I started my scratch from that.)


If you are looking for a "real" golang game server, you may find the following repos helpful:

(Both are described in Chinese only.)

And also less mature (IMO) one:


Q: Why a chat server?

A: Many such kinds of server frameworks choose chat server to demo usage, such as Boost.asio, Node.js, Pomelo distributed game server, etc.

Build and Run

  1. First, you need to install golang, of course:

Download it from https://golang.org/dl/, or install go via your package management tool:

For Ubuntu:

sudo apt-get install golang

For Mac OS X:

brew install go
  1. Now, just build.

cd into the repo directory.

To build the server, execute:

go build century.go

To build the benchmarker, execute:

go build chat_bench.go
  1. Run

3.1 Run the chat server:

./century

3.2 Run the chat client:

Client: You can use telnet as the client:

telnet localhost 6666 

type anything.

  1. Bench
./chat_bench

Benchmark Result

Benchmarking: 127.0.0.1:6666
3 clients, running 8 bytes, 5 sec.

Speed: 85009 request/sec, 56940 response/sec
Requests: 425048
Responses: 284704

(Explain: I tuned the bencher not to wait for all the responses.)