游戏server设计的一些感悟
Author:Echo Chen(陈斌)
Email:chenb19870707@gmail.com
Date:September 30th, 2014
时间荏苒。转眼间已经做游戏一年了,第一款卡牌游戏《完美神话》也已经測试上线了。十一之后開始推广渠道。这一年经历了无数次崩服、回档、卡顿后。如今server最终基本稳定。对于程序猿来说出问题是个好事情,仅仅有在问题面前才干高速成长。
在这里把这一年在server瓶颈中所入的坑做一个总结,希望对大家有帮助。
1.尽量降低内存拷贝
memcpy对于server性能影响是很大的,以下给出memcpy的性能測试,能够看到在拷贝1M的时候已经用到0.7s,这对server性能影响是很巨大的;此外。放入大量对象的容器在拷贝时。容器内对象都会进行拷贝构造。也很消耗资源。
避免的方法:假设是大容量的容器。尽量的选择放入指针。
假设是收发缓冲区,能够选择环形队列。结合writev,readv 避免memcpy,实现高效收发。
拷贝size 消耗时间(微秒) 1k 350 10k 5502 100k 96624 1M 2.避免大容器遍历
遍历大容器是很耗性能的,应该尽量避免。比如我们在设计消息系统的时候有个消息池,里面有10W的消息指针,之前未考虑到性能。每一个玩家登陆都会来变量这个池。结果300个玩家上来CPU就到了100%。通过性能检測工具perf查到有80%的CPU时间都消耗在了遍历这个池上。
避免的方法:用时间换空间,巧用数据结构,用map、红黑树建立多维索引,尽量降低遍历。
3.尽力降低加锁
多线程对锁的竞争是很激烈的,加锁对性能的影响是很巨大的。我们知道,单生产/单消费模式的共享队列是不须要加锁同步的(kfifo),所以尽量将多对一的队列拆分多个一对一的队列。这样就能够避免加锁了。比如我们的数据库是16个worker线程。假设公用一个队列必须加锁。势必竞争很激烈。
我们对每个worker线程维护了一个跟主线程的队列。这样就能够无锁訪问了。
4.降低内存的分配和释放
内存的频繁new 和delete不仅消耗性能,并且easy缠上大量的内存碎片 。对于游戏server而言,好的方法是用内存池,生成装备池、卡牌池、技能池等。不够时增量添加。假设须要释放,採用tcmalloc是一个不错的选择。
眼下能想到的就这么多。以后再继续补充,假设有什么错误和不明确的地方,欢迎大家指出。
-
Echo Chen:Blog.csdn.net/chen19870707
-
游戏server设计的一些感悟的更多相关文章
- Java8 Lambda表达应用 -- 单线程游戏server+异步数据库操作
前段时间我们游戏server升级到开发环境Java8,这些天,我再次server的线程模型再次设计了一下,耗费Lambda表情. LambdaJava代码.特别是丑陋不堪的匿名内部类,这篇文章主要就是 ...
- h2engine游戏服务器设计之聊天室示例
游戏服务器设计之聊天室示例 简介 h2engine引擎建群以后,有热心网友向我反馈,想尝试h2engine但是没有服务器开发经验觉得无从入手,希望我能提供一个简单明了的示例.由于前一段时间工作实在忙碌 ...
- 课程设计个人报告——基于ARM实验箱的捕鱼游戏的设计与实现
课程设计个人报告--基于ARM实验箱的捕鱼游戏的设计与实现 一.个人贡献 参与课设题目讨论及部分过程 资料收集 负责代码调试 捕鱼游戏相应功能的实现 实验环境 Eclipse软件开发环境: ARM实验 ...
- FPS游戏服务器设计的问题 【转】
一.追溯 去gameloft笔试,有一个题目是说: 叫你去设计一个FPS(第一人称射击游戏),你是要用TCP呢还是要用UDP,说明理由 . 二.学习 这是两篇网上找到的文章,写非常不错. 当时笔试的时 ...
- 游戏server之server优化思路
本文仅仅是提供一些游戏server优化思路,当中一些思路是用在不同场合的,不是同个架构的.须要依据应用场景选用合适方式. 本文的引用的文章都是在自己写的在本博客内的.也都是上线开几百个服的成熟项目的. ...
- (转)FPS游戏服务器设计的问题
FPS游戏服务器设计的问题出处:http://www.byteedu.com/thread-20-1-1.html一.追溯 去gameloft笔试,有一个题目是说: 叫你去设计一个FPS(第一人称射击 ...
- 基于cocos2d-x的游戏框架设计——李成
视频:http://v.youku.com/v_show/id_XMzc5ODUyMTI4.html?f=17330006 网易科技讯 3月31日,第四届CocoaChina开发者大会暨Cocos2d ...
- Scut游戏server引擎Unity3d访问
Scut提供Unity3d Sdk包.便利的高速发展和Scut游戏server对接: 看Unity3d示为以下的比率: 启动Unity3d项目 打开Scutc.svn\SDK\Unity3d\Asse ...
- Elixir游戏服设计五
在<Elixir游戏服设计一>里提到,按照系统功能划分成app要保证原子性很难, 现在想想也没那么难.保证原子性,无非就是需要某个单点去完成操作.那么选择玩家进程去做原子性工作就可以了. ...
随机推荐
- Java中Synchronized和Lock的使用
Lock的锁定是通过代码实现的,而 synchronized 是在 JVM 层面上实现的 synchronized在锁定时如果方法块抛出异常,JVM 会自动将锁释放掉,不会因为出了异常没有释放锁造成线 ...
- Node.js实现简单的爬取
学习[node.js]也有几天时间了,所以打算写着练练手:索然我作为一个后端的选手,写起来还有那么一丝熟悉的感觉.emmm~~ ‘货’不多讲 ,开搞........ 首先是依赖选择: 代码块如下: ...
- 洛谷 P1708 天然气井 题解
https://www.luogu.org/problemnew/show/P1708 这道题还是比较好的. 读完题目我们先想想如何计算某个天然气井($x_1,y_1$)和中转站($a_1,b_1$) ...
- Socket通信时服务端无响应,客户端超时设置
背景:在写一个客户端的socket程序,服务端没有返回消息,客户端一直在等待. 目标:我需要设置一个时间,如果超过这个时间客户端自动断开连接.最好是在服务端实现,客户端对我来说不可控.
- mysql两种常用备份工具
一.mysqldump备份: 在开启GTID模式时,在master上执行的备份: --set-gtid-purged=OFF 在开启GTID模式时,要在slave上执行,想重新搭建一套slave环境. ...
- 深入Linux内核架构——简介与概述
一.内核的任务 纯技术层面上,内核是硬件与软件的之间的一个中间层.作用是将应用程序的请求传递给硬件,并充当底层驱动程序,对系统中的各种设备和组件进行寻址. 从应用程序视角上看,内核可以被认为是一台增强 ...
- python3.6以上 asyncio模块的异步编程模型 async await语法
这是python3.6以上版本的用法,本例是python3.7.2编写使用asyncio模块的异步编程模型,生产这消费者,异步生产,用sleep来代替IO等待使用async和await语法来进行描述a ...
- vue ui组件muse-ui的使用
安装 npm install muse-ui typeface-roboto material-design-icons vuex axios --save Muse UI 是一套 Material ...
- POJ 1161 Walls(Floyd , 建图)
题意: 给定n个城市, 然后城市之间会有长城相连, 长城之间会围成M个区域, 有L个vip(每个vip会处于一个城市里)要找一个区域聚会, 问一共最少跨越多少个长城. 分析: 其实这题难就难在建图, ...
- UVALive - 6275 Joint Venture (二分)
题意: 给定一个整数w, 然后给定n个数, 问有没有两个数之和恰好为w 分析: 现将n个数数组a[]排序, 然后用两个变量i,j指向开头和末尾, 如果a[i] + a[j] > w, i++, ...