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。也非常方便进行数据加解密。

相关推荐
星恒讯工业路由器5 分钟前
星恒讯便携移动路由器的好处
网络·5g·智能路由器·信息与通信·wifi6·便携
tudoSearcher6 分钟前
日志、指标、链路追踪:可观测性三支柱深度解析
运维·服务器·网络·prometheus
去码头整点薯条9830 分钟前
网络实验报告8
网络
sdm0704271 小时前
网络原理-2.传输层协议TCP
网络·网络协议·tcp/ip
Oo9201 小时前
Prompt 在 NLP 中的应用——从一条 HTTP 请求说起
http
imDwAaY1 小时前
贝叶斯网络到粒子滤波Python算法实现 CS188 Proj4 学习笔记
网络·人工智能·笔记·python·学习·算法
米丘2 小时前
HTTP 3xx 重定向类状态码
http·node.js
超梦dasgg3 小时前
关路由器要等 30 秒才能再开的原因(标准断电等待 30s 原理)
网络·智能路由器
网安小白的进阶之路3 小时前
B模块 安全通信网络 第二门课IPv6与WLAN 02
网络·安全·智能路由器
网络与设备以及操作系统学习使用者3 小时前
路由器如何实现跨VLAN通信
运维·网络·学习·华为·智能路由器