HTTPS对网站SEO的影响。

HTTPS对网站SEO的影响。

1 前言

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

本文主要介绍https对用户体验的影响。

本文最早发表于百度运维部官方博客

2 HTTPS对访问速度的影响

在介绍速度优化策略之前,先来看下HTTPS对速度有什么影响。影响主要来自两方面:

1. 协议交互所增加的网络RTT(round trip time)。

2. 加解密相关的计算耗时。

下面分别介绍一下。

2.1 网络耗时增加

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

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

HTTPS对网站SEO的影响。

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

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

HTTPS对网站SEO的影响。

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

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

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

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

b) 浏览器处理302跳转也需要耗时。

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

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

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

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

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

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

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

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

b) 浏览器首先获取证书里的CA域名。

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

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

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

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

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

a) 完全握手阶段二主要是密钥协商。

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.2 计算耗时增加

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

1, 浏览器计算耗时

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

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

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

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

e) ECC密钥交换时,需要根据服务端公钥计算master key。

f) 应用层数据对称加解密。

g) 应用层数据一致性校验。

2, 服务端计算耗时

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

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

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

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

e) 应用层数据对称加解密。

f) 应用层数据一致性校验。

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

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

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/45241.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
优化家优化家订阅用户
上一篇 2022年6月30日 00:18
下一篇 2022年6月30日 00:19

相关推荐

  • 网站建设的价格受那些因素影响呢。

    网站价格是需求者关心的问题。源程序开发的程序价格一般都不便宜。众所周知,源程序开发的程序性能更好,而且耗费大量时间。那么什么因素影响网站建设的价格呢? 影响网站建设报价的因素主要有五个: 1.不同的网站建…

    2022年9月10日
    074
  • 为什么蓝色会成为UI设计中最常用的色彩。

    你可能已经猜到这篇文章是关于蓝色的。毫无疑问,蓝色是UI设计中最重要的颜色,也是使用范围最广、最常用的色彩。在你的手机当中,许多APP都采用了蓝色的LOGO,而它们的UI也大多也将蓝色作为主色调,Facebook、Twit…

    2022年7月4日 建站资讯
    0126
  • 教你如何利用SEO优化实现精准引流。

      很多新手可能会觉得,搜索引擎排名是比较难做的,但是只要你掌握了方法,其实它的操作也是很简单的。本文我主要从以下几方面来展开详细的分享:  1、如何挖掘更多更精准的关键词?  2、如何选择最佳关键词发布平台…

    2023年6月28日
    03
  • 老网站为什么排名上不去。

    很多相信SEO的人都有这样一个疑惑,就是一个网站建立了好几年,一直在做优化,但是为什么没有排名呢?针对这样的问题,我也去查了很多网站,发现问题出在哪里。 第一,内容的新颖性不够 每个人都知道一篇文章在网站…

    2022年9月10日
    069
  • 分享移动端SEO优化怎么做可以有好的展现。

      随着移动端流量的暴涨,也让很多企业开始重视移动端网站流量的获取,而要想让自己的网站能够在搜索引擎中占据一个好的排名位置,对于网站优化的技巧就要有一定的了解,但移动端与PC端的优化方式也有很大的差异。…

    2023年6月22日
    02
  • 分享网站建设怎样会更有层次感。

    我们先来说一下什么是层次感?层次感就是将页面中每一个元素都合理地、清楚地、有机地结合在一起,使得页面更舒适、愉悦。简单来说就是舒适。下面我们就来讨论一下网站建设怎样设计网站页面,可以提升网站的层次感。…

    2023年6月8日
    01
  • 网站建设的一些基本步骤。

    想要了解网站建设基本步骤的朋友一部分是想要后期从事网站建设行业,而另一部分朋友则是想要了解清楚步骤后再开始做网站不容易被不良的上海网站建设公司坑骗,不管出于哪种情况,凡是看过穹拓小编文章的朋友希望小…

    2022年7月4日
    0106
  • WordPress禁用站内搜索功能。

    站内搜索是大多数Wordpress网站常见的功能,能够让访客轻松的找到自己想看的文章,提高信息获取的效率,但是相对来说,搜索功能也是一个非常耗费性能的地方,尤其是使用低性能服务器或者数据量非常大的网站,每次搜…

    2022年10月24日 wordpress开发
    033

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息