Spring Boot 启用 http2 协议

33 篇文章 0 订阅
29 篇文章 2 订阅

Spring Boot 启用 http2 协议

HTTP2是万维网(WWW)发布的HTTP网络协议主流版本,也是当前HTTP协议的最新版本(1997年发布的HTTP 1.1)。它来源于SPDY协议,最初由谷歌开发。

1. HTTP2的优势

所有主流的浏览器,如Chrome, Opera, Firefox, Safari, Edge浏览器都支持这个协议。相对于HTTP1.1协议,HTTP2的优势主要包括下面几点。
在这里插入图片描述

1.1 多路复用和并发性

一般渲染HTML页面可能需要JS, CSS,图像等多个资源文件,需要从服务器获取资源从而获得更好的界面体验。使用HTTP1.1协议,HTML响应客户端每个JS, CSS,单独图像文件的请求,每个都需要一个TCP连接请求,需要占用昂贵的服务器和网络资源。

在HTTP2协议中有所改进,不再是客户端在单个HTML页面中请求多个所需的资源。服务器通过一个TCP连接将页面中所需响应推送给客户端,这样服务器提供必要的数据给浏览器渲染页面,浏览器无需等待第一个响应。
在这里插入图片描述

1.2 流优先级

客户端可以指示对服务器来说哪些资源比其他资源更重要。为了提供资源优先级,HTTP2标准有个特性来提供相关的资源权重和依赖关系(如果流依赖于另一个流)。

  1. 每个流可以分配1-256之间的整数权重。

  2. 每个流可以提供对其他流的显式依赖。

  3. 依赖关系和权重的结合将允许客户端构造优先级树,该树表示客户端希望如何接收资源的偏好。服务器将使用这些信息对流处理进行优先级排序,并控制系统资源,如CPU、内存和其他资源,一旦响应可用,它将分配带宽以确保向客户端交付高优先级响应。

为了加快页面加载时间,所有新的浏览器基于资源类型,其在页面中位置,甚至参考以前访问优先级的经验值排列请求优先级,如果在之前访问的渲染中某个资源被阻塞,则同样资源在未来的请求可能会被优先考虑。

1.3 头部压缩

每个HTTP传输携带一组头信息,描述传输资源及其属性。在HTTP1.1协议中,所有的头部属性值以明文格式发送,每个请求将占用500-800字节,如果使用HTTP cookie,大小还会增加。HTTP2通过使用HPACK压缩格式技术提供了更好的解决方案,描述如下:

  1. 传输的头部字段通过静态霍夫曼编码,大大减少了传输大小。

  2. 它还需要服务器和客户端维护和更新以前发送的头部字段索引列表,然后使用它作为参考来有效地编码以前传输的值。霍夫曼提供了传输时要压缩的特定值,而传输前的索引列表使我们能够通过传输索引值对重复值进行编码,这些索引值可用于有效地查找和重新构建完整的头部键和值。
    在这里插入图片描述

1.4 服务器推送

服务器将把所有未被请求的依赖资源推送给客户端。
在这里插入图片描述

1.5 流控制

流控制机制来阻止发送方给接收方发送过多数据,有很多原因会导致可能无法处理这些过量数据,如接收方在负载较重的情况下无法响应,或者没有足够的缓冲空间去处理数据。

HTTP2通过提供接收窗口(rwnd)解决了这些问题,窗口设定通信发送方和接收方之间传输数据的大小。当第一次建立连接时,它将使用默认设置。如果在下载文件时,服务器正向客户端流传输大量数据,此时接收窗口可能会成为限制因子;类似的,当客户端向服务器发送大量数据时,服务器接收窗口将成为限制因子。无论怎样,窗口大小越小则限制越大。

如果窗口为零,则表明不能再发送数据,除非应用清除缓冲区中已有数据。这种流程机制适用在连接整个生命周期中持续运行的每个TCP连接:每个请求包都有两端最新的RW值,根据发送方和接收方的状态以及进程速度动态地切换数据流速率。

HTTP/2不再支持HTTP 1.1的分块移位编码机制,因为它提供了自己的、更有效的数据流机制。
在这里插入图片描述

2. Spring Boot 配置

无需更改/更新任何Java应用程序或API来适用HTTP2协议,使用HTTP2可使Java应用程序工作得更好,在客户端和服务器上消耗资源更少。

2.1 tomcat 配置

只有Tomcat 9 版本之后版本才支持HTTP2协议。在 conf/server.xml 中增加内容:

<Connector port="8443" protocol="org.apache.coyote.http11.Http11AprProtocol" maxThreads="150" SSLEnabled="true">
<UpgradeProtocol className="org.apache.coyote.http2.Http2Protocol"/>
<SSLHostConfig honorCipherOrder="false">
<Certificate certificateKeyFile="conf/ca.key" certificateFile="conf/ca.crt"/>
</SSLHostConfig>
</Connector>

2.2 Spring Boot配置

如果服务器已经支持HTTP2,Spring Boot增加下面配置属性:

server.http2.enabled=true

3. 总结

本文介绍了HTTP2相对与HTTP1.1的主要特性,并说明如何配置Tomcat和Spring Boot以启用HTTP2协议。

要在Spring Boot启用SSL证书,需要进行以下步骤: 1. 在Spring Boot的配置文件(application.yml或application.properties)中添加SSL相关的配置信息。这些配置包括启用SSL、证书文件路径、证书密码和证书类型等。示例配置如下: ``` server: port: 443 ssl: enabled: true key-store: classpath:证书名称.jks key-store-password: 证书密码 key-store-type: JKS ``` 在该示例中,将服务器端口设置为443,并启用SSL。证书文件的路径设置为classpath:证书名称.jks,证书密码为指定的密码,证书类型为JKS。 2. 获取SSL证书。您可以通过去阿里云、腾讯云等提供SSL证书的服务商申请证书。对于个人用户,您也可以申请免费的证书。申请证书后,您会得到一个压缩包,里面包含了jks格式的证书和密码。 3. 将证书文件添加到Spring Boot项目中。您可以将jks格式的证书文件放置在项目的资源目录下,例如src/main/resources目录。 4. 重新启动Spring Boot应用程序。在重新启动应用程序后,Spring Boot将会加载配置的SSL证书并启用SSL功能。 通过以上步骤,您可以在Spring Boot启用SSL证书。这样可以增加您的网站安全性,并使其看起来更加可靠。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Spring Boot配置SSL证书(开启https)](https://blog.csdn.net/weixin_43118617/article/details/122199258)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值