只因把 https 改成 http,带宽减少了 70%!
当前位置:点晴教程→知识管理交流
→『 技术文档交流 』
起因是一个高并发的采集服务上线后,100m的上行很快就被打满了。 但是!这个请求只是一个 GET 请求,同时并没有很大的请求体,这是为什么呢? 于是使用 charles 重新抓包后发现,一个 request 的请求居然要占用 1.68kb 的大小! 其中TLS Handshake 就占了 1.27kb。 这种情况下,需要的上行带宽就是: 也就说明100mbps的上行为何被轻松打满 TLS Handshake是什么来头,竟然如此大?首先要知道HTTPS全称是:HTTP over TLS,每次建立新的TCP连接通常需要进行一次完整的TLS Handshake。在握手过程中,客户端和服务器需要交换证书、公钥、加密算法等信息,这些数据占用了较多的字节数。 TLS Handshake的内容主要包括:
这个过程不仅耗时,还会消耗带宽和CPU资源。 因此想到最粗暴的解决方案也比较简单,就是直接使用 HTTP,省去TLS Handshake的过程,那么自然就不会有 TLS 的传输了。 那么是否真的有效呢?验证一下就知道。 将请求协议改成 http 后: 可以看到请求头确实不包含 TLS Handshake了! 整个请求只有 0.4kb,节省了 70% 的大小 目标达成 因此可以说明:在一些不是必须使用 https 的场景下,使用 http 会更加节省带宽。 同时因为减少了加密的这个过程,可以观察到的是,在相同的并发下,服务器的负载有明显降低。 那么问题来了如果接口必须使用 https那怎么办呢? 当然还有另外一个解决方案,那就使用使用 通过启用 Keep-Alive, 对于高并发的场景也非常适用。 要注意的是keep-alive 是有超时时间的,超过时间连接会被关闭,再次请求需要重新建立链接。 Nginx 默认的
作者:麦麦麦造 链接:https://juejin.cn/post/7409138396792881186 来源:稀土掘金 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 该文章在 2024/9/2 10:38:36 编辑过 |
关键字查询
相关文章
|