GoRoutine可以替代C Socket的多线程来做游戏服务器么?

老师留了一个游戏服务器作业,我想用Go来写,节省代码量,顺便用用新技术~

但是老师在讲服务器要求的结构的时候用了多进程来分配客户端连接数量。我查了资料,貌似Go没有提供很明显的多进程接口,倒是有rpc包,感觉不太靠谱……我自己还是倾向于用GoRoutine搭建,便于线程间通信。我想问下,这样做靠谱么?

阅读 11k
3 个回答

用Go写游戏服务器是一个非常棒的选择,当然主要一个原因就是Go语言特有的Goroutine和Channel。

看了这个问题后我不是很清楚你们是在学习多线程编程还是分布式架构。如果是多线程编程,对应Go的实现当然是Goroutine和Channel。如果是分布式架构,用HTTP编程应该最适合你,模型足够简单。HTTP编程我就不介绍了,我们之前写的《Go语言编程》中也有介绍。如果要多个HTTP服务器分摊客户端请求,前面加个Nginx作LB应该就可以了。

Go语言中控制Goroutine数量有挺多灵活的办法的,一般最简单的就是预先直接创建这么多个Goroutine,然后每个Goroutine自身是一个死循环,持续从作为参数传入的Channel中读取需要处理的数据包。

这里就先不展开了,看你具体的需求再论。我以前参与的游戏项目都是用C++然后是IOCP和epoll之类的处理高并发。可惜当时还没有Go可以用,否则应该会更有乐趣。

C多进程或多线程开发明显是史前时代了,知识结构落后啊,多看点网络编程的书,goroutine绝对秒杀c多线程。

新手上路,请多包涵

给你一个其他的选择node.js,golang也是可以的

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏