Why Not Http?

游戏服务器开发主要是基于socket,或者websocket,很少采用http(可能有部分非常轻量级的服务器选择http)。这是什么原因呢?我们先来看看socket与http之间的区别。

socket与http之间的区别

|----------|------------|----------------|
| | socket | http |
| TCP/IP协议 | 工作在传输层 | 工作在应用层 |
| 链接状态 | 长链接 | 短链接,请求无状态 |
| 通信方向 | 双向通信 | 单项通信,基于请求-响应模式 |
| 数据格式 | 私有协议,自定义格式 | 公有协议 |
[socket与http对比]

选择socket的原因

游戏服务器主要选择socket与客户端进行通信,原因无非是选择socket的优势以及选择http的劣势。下面分成几点来解释。

第一,http是单向通信,基于请求-响应模式。

只能客户端发送请求,服务器才能返回推送。这是一个致命缺陷,也是游戏服务器不采用http的一个最主要的原因。因为服务器需要经常主动推送消息,例如各种icon小红点,系统跑马灯等等。当然,针对http的单向通信,也出现了一些反向ajax技术,或者称为服务端推送(server side push),例如java的第三方依赖cometd。

第二,http是无状态,短链接的。

http无状态特性,决定了每个请求都是独立的。但是很多时候系统是需要状态的,客户端不得不通过cookies或者session来记录会话的状态。同时,http也是短链接的。服务器甚至不知道请求是否来自于预期的客户端,只要有cookies数据参数,任何能发送http数据的终端都能模拟客户端数据发送。这也给客户端数据作弊留下后门,加大服务器风险。

第三,http是公有协议,数据包大,传输安全性差。

http工作在TCP/IP协议中的应用层,具有标准的数据参数格式。服务端传送数据的格式主要是json或者xml,这两种格式属于文本格式,数据包大。

socket工作在TCP/IP协议中的传输层,没有标准协议格式,采用私有协议栈设计。服务端客户端之间是通过字节流来传输数据的,可以采取一些紧凑的数据格式,例如protobuf。也非常方便进行数据加解密。

相关推荐
唯创知音2 分钟前
WT2605A录音方案实现高保真音频采集本地存储云端同步!
网络·音视频·录音芯片·录音方案·录音上传
@CLoudbays_Martin117 分钟前
什么是IP黑洞?
网络·网络协议·tcp/ip
qqssss121dfd11 分钟前
计算机网络(第8版,谢希仁)第三章习题解答
网络·计算机网络·php
kaikaile19952 小时前
LDPC编解码与未编码信息的误码率比较
网络
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ2 小时前
aspect实现请求校验,但是WebSocket 端点类不能被 AOP 代理解决方案
网络·websocket·网络协议
数字护盾(和中)2 小时前
从边界突破到物理破坏:APT 工控攻击链路与防御闭环
网络
Saniffer_SH3 小时前
【每日一题】PCIe答疑 - 接大量 GPU 时主板不认设备或无法启动和MMIO的可能关系?
运维·服务器·网络·人工智能·驱动开发·fpga开发·硬件工程
大白的编程日记.3 小时前
【计算网络学习笔记】Socket编程UDP实现简单聊天室
网络·笔记·学习
织元Zmetaboard3 小时前
什么是态势感知大屏?
网络·数据库
Web3VentureView3 小时前
培养全球Web3人才:SYNBO商学院正式启动运营
网络·金融·重构·web3·区块链