当前位置:首页HTTPS对网站性能SEO有哪些影响? 举报文章

HTTPS对网站性能SEO有哪些影响?

作者:admin    来源:用户投稿    时间:2015.6.11   

https和http有什么区别 HTTPS端口 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和http有什么区别, HTTPS端口, HTTPS证书, 网站SEO

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

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

  

站长之家, https和http有什么区别, HTTPS端口, 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以上。

好文打赏,给Ta鼓励
扫一扫用手机阅读本文
Tags:网站  性能  哪些  影响  
  • 相关搜索
图片推荐
    为什么表情包公司LINE成了今年以来最大科技IPO?

    为什么表情包公司LINE成了今年以来最大科技IPO?

    或许你对LINE不熟悉,但是你绝对不会不知道那只棕色呆萌的布朗熊,和热情活泼的可妮兔。至少每个去过日韩的国人,几乎有过代购这家社交应用公司设计出来的各种卡通小物件的经历。  因为实在没办法,LINE的
    猎豹移动发布面向全球的广告平台

    猎豹移动发布面向全球的广告平台

    [摘要]2015年第一季度,猎豹移动自称全球移动应用总安装量已经达到13.4亿。  腾讯科技讯(梁辰)6月16日,猎豹移动宣布正式面向全球市场发布猎豹广告平台,后者是一个集合了品牌广告主、应用发行商和
    论初创公司的几款低成本营销大法

    论初创公司的几款低成本营销大法

    很多公司处于初创期,对于营销也只是停留在传统的电视、报纸或者线下拜访,有很多虽然也知道互联网营销,但有时却往往打不到预期的效果。而且很多初创公司的营销预算负担不起庞大的一些活动、会议等,只能白白错失良
    微店你Y产品这么垃圾 小马哥他造吗?

    微店你Y产品这么垃圾 小马哥他造吗?

    微信火爆促涨了很多微商,做微商大伙都会需要使用到一些第三方的平台。很多人都会选口袋购物的那个微店,我也是该微店的使用者,但是这个APP实在是让我无语,说实话你们能搞好点我也不至于流失这么多单。你知道吗
    借力Google+ 推广 成为圈子牛人

    借力Google+ 推广 成为圈子牛人

    圈子分享在google+上已成燎原之势,是网络推广的得力助手。接下来大全吧将带领大家详细了解一下,如何借助google+进行推广。  2周前,大全吧的圈子只有600左右的人。今天早上一看,已经突破30
    扎克伯格姐姐谈硅谷创业七大趋势

    扎克伯格姐姐谈硅谷创业七大趋势

    作为前Facebook的市场总监,兰迪扎克柏格(Randi Zuckerberg)协助弟弟将这个社交网站逐渐从大学校园、企业,逐步打造成全球最大的社交媒体。她在任内还推动了Facebook在全球不同市
    搜索引擎排名背后的逻辑 要让用户想到我们

    搜索引擎排名背后的逻辑 要让用户想到我们

    SEO归根结底是跟搜索引擎打交道的。搜索引擎也是由人发明创造的,那就脱离不了人的行为,只要我们认清这种行为。认清这种行为背后的逻辑。就会给我们的操作指明方向。  你有没有每天不停的打开百度,搜索自己行
    消费互联网创业者,是时候悬崖勒马了

    消费互联网创业者,是时候悬崖勒马了

    欢迎关注创事记的微信订阅号:sinachuangshiji  文/磐石之心 (微信公众号 panshizhixin18)  关于大众创业,我已经写过《互联网+正在上演一场大跃进》、《O2O创业99%会
你是怎么知道非凡网赚网的?
  •   
  • 联系QQ 邮箱:976382653@qq.com 微信:976382653
    在线留言
    发布软文
    广告自助购
    文章调用
    常见问题
    保存到桌面