广告
返回顶部
首页 > 资讯 > 精选 >大型网站的HTTPS实践(三)——HTTPS对性能的影响
  • 382
分享到

大型网站的HTTPS实践(三)——HTTPS对性能的影响

2023-06-03 22:06:28 382人浏览 安东尼
摘要

前言https在保护用户隐私,防止流量劫持方面发挥着非常关键的作用,但与此同时,HttpS也会降低用户访问速度,增加网站服务器的计算资源消耗。本文主要介绍HTTPS对性能的影响。HTTPS对访问速度的影响在介绍速度优化策略之前,先来看下HT

前言

https在保护用户隐私,防止流量劫持方面发挥着非常关键的作用,但与此同时,HttpS也会降低用户访问速度增加网站服务器的计算资源消耗。本文主要介绍HTTPS对性能的影响。

HTTPS对访问速度的影响

在介绍速度优化策略之前,先来看下HTTPS对速度有什么影响。影响主要来自两方面:协议交互所增加的网络RTT(round trip time)和加解密相关的计算耗时。下面分别介绍一下。

1网络耗时增加

由于HTTP和HTTPS都需要DNS解析,并且大部分情况下使用了DNS缓存,为了突出对比效果,忽略主域名的DNS解析时间。

用户使用HTTP协议访问http://www.baidu.com(或者www.baidu.com)时会有如下网络上的交互耗时:

大型网站的HTTPS实践(三)——HTTPS对性能的影响

图1  HTTP首个请求的网络耗时

可见,用户只需要完成TCP三次握手建立tcp连接就能够直接发送HTTP请求获取应用层数据,此外在整个访问过程中也没有需要消耗计算资源的地方。

接下来看HTTPS的访问过程,相比HTTP要复杂很多,在部分场景下,使用HTTPS访问有可能增加7个RTT。如下图:

大型网站的HTTPS实践(三)——HTTPS对性能的影响

图2  HTTPS首次请求对访问速度的影响

HTTPS首次请求需要的网络耗时解释如下:

  1. 三次握手建立TCP连接。耗时一个RTT。

  2. 使用HTTP发起GET请求,服务端返回302跳转到https://www.baidu.com。需要一个RTT以及302跳转延时。

    1. 大部分情况下用户不会手动输入https://www.baidu.com来访问HTTPS,服务端只能返回302强制浏览器跳转到HTTPS。

    2. 浏览器处理302跳转也需要耗时。

  3. 三次握手重新建立TCP连接。耗时一个RTT。

    1. 302跳转到HTTPS服务器之后,由于端口和服务器不同,需要重新完成三次握手,建立TCP连接。

  4. TLS完全握手阶段一。耗时至少一个RTT。

    1. 这个阶段主要是完成加密套件的协商和证书的身份认证。

    2. 服务端和浏览器会协商出相同的密钥交换算法、对称加密算法、内容一致性校验算法、证书签名算法、椭圆曲线(非ECC算法不需要)等。

    3. 浏览器获取到证书后需要校验证书的有效性,比如是否过期,是否撤销。

  5. 解析CA站点的DNS。耗时一个RTT。

    1. 浏览器获取到证书后,有可能需要发起OCSP或者CRL请求,查询证书状态。

    2. 浏览器首先获取证书里的CA域名。

    3. 如果没有命中缓存,浏览器需要解析CA域名的DNS。

  6. 三次握手建立CA站点的TCP连接。耗时一个RTT。

    1. DNS解析到IP后,需要完成三次握手建立TCP连接。

  7. 发起OCSP请求,获取响应。耗时一个RTT。

  8. 完全握手阶段二,耗时一个RTT及计算时间。

    1. 完全握手阶段二主要是密钥协商。

  9. 完全握手结束后,浏览器和服务器之间进行应用层(也就是HTTP)数据传输。

当然不是每个请求都需要增加7个RTT才能完成HTTPS首次请求交互。大概只有不到0.01%的请求才有可能需要经历上述步骤,它们需要满足如下条件:

  1. 必须是首次请求。即建立TCP连接后发起的第一个请求,该连接上的后续请求都不需要再发生上述行为。

  2. 必须要发生完全握手,而正常情况下80%的请求能实现简化握手。

  3. 浏览器需要开启OCSP或者CRL功能。Chrome默认关闭了OCSP功能,Firefox和IE都默认开启。

  4. 浏览器没有命中OCSP缓存。OCSP一般的更新周期是7天,Firefox的查询周期也是7天,也就说是7天中才会发生一次OCSP的查询。

  5. 浏览器没有命中CA站点的DNS缓存。只有没命中DNS缓存的情况下才会解析CA的DNS。

2计算耗时增加

上节还只是简单描述了HTTPS关键路径上必须消耗的纯网络耗时,没有包括非常消耗CPU资源的计算耗时,事实上计算耗时也不小(30ms以上),从浏览器和服务器的角度分别介绍一下:

  1. 浏览器计算耗时

    1. RSA证书签名校验,浏览器需要解密签名,计算证书哈希值。如果有多个证书链,浏览器需要校验多个证书。

    2. RSA密钥交换时,需要使用证书公钥加密premaster。耗时比较小,但如果手机性能比较差,可能也需要1ms的时间。

    3. ECC密钥交换时,需要计算椭圆曲线的公私钥。

    4. ECC密钥交换时,需要使用证书公钥解密获取服务端发过来的ECC公钥。

    5. ECC密钥交换时,需要根据服务端公钥计算master key

    6. 应用层数据对称加解密。

    7. 应用层数据一致性校验。

  2. 服务端计算耗时

    1. RSA密钥交换时需要使用证书私钥解密premaster。这个过程非常消耗性能。

    2. ECC密钥交换时,需要计算椭圆曲线的公私钥。

    3. ECC密钥交换时,需要使用证书私钥加密ECC的公钥。

    4. ECC密钥交换时,需要根据浏览器公钥计算共享的master key。

    5. 应用层数据对称加解密。

    6. 应用层数据一致性校验。

由于客户端的CPU和操作系统种类比较多,所以计算耗时不能一概而论。手机端的HTTPS计算会比较消耗性能,单纯计算增加的延迟至少在50ms以上。PC端也会增加至少10ms以上的计算延迟。

服务器的性能一般比较强,但由于RSA证书私钥长度远大于客户端,所以服务端的计算延迟也会在5ms以上。
总  结

HTTPS在保证数据安全性的同时,对服务性能也造成了一些影响。在本文中,我们着重介绍了HTTPS从网络耗时和加密解密两方面对于服务性能的影响。在下一篇系列文章中,我们将为大家带来百度在减小HTTPS对性能影响方面的方法和经验。

文章整理自百度HTTPS技术联合团队

--结束END--

本文标题: 大型网站的HTTPS实践(三)——HTTPS对性能的影响

本文链接: https://www.lsjlt.com/news/235761.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 大型网站的HTTPS实践(三)——HTTPS对性能的影响
    前言HTTPS在保护用户隐私,防止流量劫持方面发挥着非常关键的作用,但与此同时,HTTPS也会降低用户访问速度,增加网站服务器的计算资源消耗。本文主要介绍HTTPS对性能的影响。HTTPS对访问速度的影响在介绍速度优化策略之前,先来看下HT...
    99+
    2023-06-03
  • 大型网站的HTTPS实践(一)——HTTPS协议和原理
    前言百度于2015年上线了全站HTTPS的安全搜索,默认会将HTTP请求跳转成HTTPS。从今天开始,我们将会分享多篇系列文章,为大家重点介绍和解析百度的HTTPS最佳实践。HTTPS协议概述HTTPS可以认为是HTTP+TLS。HTTP协...
    99+
    2023-06-03
  • HTTPS加密对我们的网站优化推广有什么影响
    这篇文章主要介绍了HTTPS加密对我们的网站优化推广有什么影响,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。  最近看到某个公号上面一篇《HTTPS全站加密可能是大势所趋》的...
    99+
    2023-06-10
  • 缓存对于 ASP 网站性能的影响有多大?
    随着互联网技术的不断发展,网站的性能优化变得越来越重要。其中,缓存是一个非常重要的优化手段。ASP 网站作为一种常见的动态网站,缓存对于其性能的影响尤为重要。本文将介绍缓存对于 ASP 网站性能的影响,并提供一些演示代码。 什么是缓存? ...
    99+
    2023-09-04
    numpy windows 缓存
  • 面试日志对ASP网站的性能有何影响?
    随着互联网的快速发展,网站已经成为人们获取信息和交流的主要方式之一。为了保证网站的正常运行和稳定性,开发人员需要对网站的性能进行优化。而面试日志也是其中一个重要的方面。 ASP网站是一种基于服务器端脚本语言开发的动态网站,广泛应用于企业网...
    99+
    2023-07-30
    load 面试 日志
  • 理解 ASP 打包和 http 缓存对你的网站性能的影响。
    ASP打包和HTTP缓存对网站性能的影响 在今天的互联网时代,网站性能是至关重要的。用户期望他们所访问的网站能够快速地加载和响应,而且这种期望正在不断提高。因此,作为网站开发者和管理员,我们需要关注网站性能,以确保我们的网站能够快速响应用户...
    99+
    2023-08-28
    打包 缓存 http
  • ASP存储API的负载优化对于网站性能的影响如何?
    随着互联网的普及,网站的访问量越来越大,对于网站的性能要求也越来越高。ASP存储API是ASP.NET网站开发中常用的一种技术,它可以实现对于数据的存储和访问。在高并发的情况下,ASP存储API的负载优化对于网站性能的影响变得尤为重要。 ...
    99+
    2023-07-29
    存储 api load
  • PHP缓存和Apache日志的交互对网站性能有什么影响?
    随着互联网的不断发展,网站的访问量也越来越大,如何提高网站的性能成为了网站开发者们的重要任务之一。在优化网站性能的过程中,PHP缓存和Apache日志的交互成为了一个备受关注的话题。 一、PHP缓存 PHP缓存是一种将PHP脚本的编译结果...
    99+
    2023-07-01
    缓存 日志 apache
  • 响应重定向对 ASP 网站的性能影响是什么?bash 如何优化响应重定向?
    响应重定向是一种常见的网站重定向技术,它是将用户从一个 URL 重定向到另一个 URL 的过程。它通常在以下情况下使用:在网站重构期间,将旧网址重定向到新网址;将非首选的域名重定向到首选的域名;将 HTTP 网址重定向到 HTTPS 网址...
    99+
    2023-08-16
    响应 重定向 bash
  • PHP-FPM性能优化实践:提高网站的响应速度和稳定性
    摘要:随着互联网的快速发展,网站性能优化变得愈发重要。作为一种常用的网站开发语言,PHP在提供灵活和快速的开发过程的同时,也面临着性能瓶颈。本文将介绍一些PHP-FPM性能优化的实践,旨在提高网站的响应速度和稳定性。具体内容包含代码示例和优...
    99+
    2023-10-21
    PHP-FPM性能优化 响应速度提升 网站稳定性增强
  • ASP 同步响应编程算法:您是否知道它对于大型网站的重要性?
    ASP(Active Server Pages)是一种基于服务器端的动态网页技术,它可以让开发者在网页中嵌入动态的内容和交互式元素。ASP 的同步响应编程算法是其核心功能之一,它可以使网站在处理大量请求时更加高效和稳定。本文将详细介绍 A...
    99+
    2023-10-13
    同步 响应 编程算法
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作