如何在项目中使用Http2.0?

上篇的每日一题讲到Http2.0的基础知识,如下:

【每日一题】(42题)谈谈你对Http2.0的理解?

那我们这一期的每日一题,我们来说说如何用nginx来配置Http2.0

本着实践出真知,我们一步一步来构建一个站点,从 Http => Https => Http2.0

也就是说,升级到Http2.0,必须是基于Https的基础上。

作者:saucxs

愿努力拼搏的你,都能在前进的道路上有所收获!


一、升级Https

最近想折腾一下服务器和Http,升级到Http2.0

升级到Http2.0就必须先升级到Https

升级Https,我们需要先在下载或者购买SSL证书中,下载cert证书,然后放到nginx服务器上。

1、查看nginx是否支持ssl

./nginx -V

查看nginx是否支持ssl

查看 configure arguments 信息中是否包含 -with-http_ssl_module 字样

2、配置ssl模块

找到之前安装 Nginx 时的解压目录,配置ssl模块:

./configure --with-http_ssl_module

配置ssl模块

3、重新编译一下nginx

因为我们在nginx的安装路径下,配置新的模块,需要重新编译一下nginx,这时候新的nginx才能拥有ssl模块。

在解压目录执行make

make

重新编译一下nginx

4、备份之前的nginx

这次是升级nginx,所以不需要执行 make install,首先备份原nginx执行脚本:

mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.old

4、备份之前的nginx

5、移动编译好的nginx到安装路径下

把新编译的nginx执行脚本拷贝到相应的目录下:

cd objs
cp nginx /usr/local/nginx/sbin/

移动编译好的nginx到安装路径下

移动编译好的nginx到安装路径下

6、最后进行平滑升级

cd ..
make upgrade

最后进行平滑升级

7、再次检查nginx是否有https模块

再次检查nginx是否有https模块

二、直接从Http升级到Http2.0

官网有支持这个,那我们先来看看官网关于这个的配置。

详细的注释已经写在配置里:

# ssl写在443端口后面。这样http和https的链接都可以用
listen 443 ssl http2 default_server;
server_name chat.chengxinsong.cn;
# HSTS的合理使用,max-age表明HSTS在浏览器中的缓存时间,includeSubdomainscam参数指定应该在所有子域上启用HSTS,preload参数表示预加载,通过Strict-Transport-Security: max-age=0将缓存设置为0可以撤销HSTS
add_header Strict-Transport-Security "max-age=63072000; includeSubdomains; preload";
ssl_certificate  /usr/local/nginx/cert/2540136_chat.chengxinsong.cn.pem;
ssl_certificate_key  /usr/local/nginx/cert/2540136_chat.chengxinsong.cn.key;
# 分配20MB的共享内存缓存,不同工作进程共享TLS会话信息
# ssl_session_cache shared:SSL:20m;
# 设置会话缓存过期时间1h
ssl_session_timeout 60m;
# TLS协议的合理配置
# 指定TLS协议的版本,不安全的SSL2和SSL3要废弃掉
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
# 启用ssl_prefer_server_ciphers,用来告诉Nginx在TLS握手时启用服务器算法优先,由服务器选择适配算法而不是客户端
ssl_prefer_server_ciphers on;
# 优先选择支持前向加密的算法,且按照性能的优先顺序排列
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
# 会话恢复的合理使用
# 配置会话票证,减少了TLS握手的开销
ssl_session_tickets on;

然后执行检查nginx配置。nginx -t

image

意思就是说:

http2.0缺少ngx_http_v2_module。nginx缺少http_ssl_module模块,编译安装的时候带上--with-http_ssl_module配置就行了。

三、查资料找原因

出现上面原因是nginx从1.9.5开始,已经用 http_v2_module 模块替换了 ngx_http_spdy_module ,并正式开始支持http2协议。

但是我的nginx是1.12.2。应该不是ngin版本问题

ngin版本

注意事项:

•1、并且需要openssl库的版本在1.0.2以上编译。1.要开启HTTP/2协议支持,需要在nginx 1.10以上版本并且需要openssl库的版本在1.0.2以上编译。•2.http2.0只支持开启了https的网站。

可能是服务器的openssl库的版本,发现是1.0.2。

openssl库的版本

所以还是要升级到更高点。

四、升级OpenSSL

在http2.0协议中,涉及到ALPN(Application Layer Protocol Negotiation,应用层协议协商)的支持,目前所有主流的Unix服务器系统中内置的OpenSSL库都低于1.0.2版本。通过使用OpenSSL的命令行工具,可以检查当前的http2服务是否支持ALPN。

找一个安装目录

1、下载最新版的OpenSSL库编译安装

wget https://www.openssl.org/source/openssl-1.1.0f.tar.gz
tar xzf openssl-1.1.0f.tar.gz
cd openssl-1.1.0f
./config --prefix=/usr/local/openssl
make && make install

2.替换旧版本库

mv /usr/bin/openssl  /usr/bin/openssl.old
mv /usr/include/openssl /usr/include/openssl.old
ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl
ln -s /usr/local/openssl/include/openssl /usr/include/openssl
#链接新库文件
ln -s /usr/local/openssl/lib/libssl.so /usr/local/lib64/libssl.so
ln -s /usr/local/openssl/lib/libcrypto.so /usr/local/lib64/libcrypto.so
#检查更新后的openssl依赖库是否是1.1.0f
strings /usr/local/lib64/libssl.so | grep OpenSSL
#显示结果表明已升级到最新版本链接库
OpenSSL 1.1.0f  25 May 2017
#配置openssl库文件的搜索路径
echo '/usr/local/openssl/lib' >> /etc/ld.so.conf
#使修改后的搜索路径生效
ldconfig -v
#查看openssl版本,结果显示升级成功
openssl version
OpenSSL 1.1.0f  25 May 2017

五、nginx开启ssl模块

默认编译的 Nginx 并不包含 h2 模块,我们需要加入参数来编译,截止发文,Nginx 1.9 开发版及以上版本源码需要自己加入编译参数,从软件源仓库下载的则默认编译。Nginx 是不再支持 SPDY。

如果你编译的 Nginx 不支持,那么在 ./configure 中加入:--with-http_v2_module ,如果没有 SSL 支持,还需要加入 --with-http_ssl_module

1、找到源码包,查看configure中是否支持http2

这时候需要去下载的时候的源码文件夹中找到这个configure。注意:不是编译之后的文件夹。

image

在"./configure"配置中,"--with"表示启用模块,也就是说这些模块在编译时不会自动构建"--without"表示禁用模块,也就是说这些模块在编译时会自动构建,若你想Nginx轻量级运行,可以去除一些不必要的模块。

执行./configure --help

image

从上图知道了nginx在编译时不会自动构建http_ssl_module和http_v2_module。所以需要重新编译nginx。

2、加入参数编译

我们的新配置信息就应该这样写:

./configure --prefix=/usr/local/nginx --with-http_v2_module --with-http_ssl_module --with-openssl=/home/soft/openssl-1.1.0f

上面的/usr/local/nginx这个路径是我们编译之后的包路径。

那么在 ./configure 中加入:--with-http_v2_module ,如果没有 SSL 支持,还需要加入 --with-http_ssl_module,加上刚才更新的openssl到1.1.0,所以需要加上--with-openssl=/home/soft/openssl-1.1.0f。

运行上面的命令即可,等配置完

配置完成后,运行命令

make

这里不要进行make install,否则就是覆盖安装

3、备份和替换

(1)然后备份原有已安装好的nginx

cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx_07_22.bak

(2)关闭nginx,然后将刚刚编译好的nginx覆盖掉原有的nginx

关闭nginx

./nginx -s quit

移动编译好的nginx到原有的nginx

cp ./objs/nginx /usr/local/nginx/sbin/

(3)启动nginx

./nginx

稍等1分钟作用,然后就可以看到http2.0的效果。

六、查看网站是否是http2.0

右键name,勾选protocol,这样就可以看到http协议。

image

上图截图网站地址:https://chat.chengxinsong.cn

上面的HappyChat已经支持Http2.0,速度是得到很大的提升。

对比一下http1.1的网站

image

上图截图网站地址:https://www.mwcxs.top

往期「每日一题」

1、JavaScript && ES6

•第 41 题:【每日一题】(41题)JS代码到底是如何被压缩的?•第 40 题:【每日一题】(40题)关于script标签,你可能不知道的地方?•第 39 题:【每日一题】(39题)谈谈JS的函数扩展?•第 30 题:【每日一题】(30题)面试官:ES6的解构赋值的理解?•第 28 题:【每日一题】(28题)面试官:原型链与构造函数结合方法继承与原型式继承的区别?•第 22 题:【每日一题】(22题)面试官问:var与const,let的主要区别是什么?•第 21 题:【每日一题】(21题)面试官问:谈谈JS中的 this 的绑定?•第 20 题:【每日一题】(20题)面试官问:谈谈JS中的 webSockets 的理解?•第 19 题:【每日一题】面试官问:谈谈JS中的 XMLHttpRequest 对象的理解?•第 18 题:【每日一题】面试官问:JS中的 Ajax 跨域与扩展 Comet ?•第 17 题:【每日一题】(17题)面试官问:JS中事件流,事件处理程序,事件对象的理解?•第 16 题:【每日一题】面试官问:JS中如何全面进行客户端检测?•第 15 题:【每日一题】面试官问:JS类型判断有哪几种方法?•第 14 题:【每日一题】面试官问:谈谈你对JS对象的创建和引申•第 13 题[每日一题]面试官问:['1', '2', '3'].map(parseInt)输出,原因,以及延伸?•第 12 题[每日一题]面试官问:JS引擎的执行过程(二)•第 11 题[每日一题]面试官问:JS引擎的执行过程(一)•第 10 题[每日一题]面试官问:详细说一下JS数据类型•第 8 题[每日一题]面试官问:谈谈你对ES6的proxy的理解?•第 7 题[每日一题]面试官问:for in和for of 的区别和原理?•第 6 题[每日一题]面试官问:Async/Await 如何通过同步的方式实现异步?•第 3 道「「每日一题」面试官问你对 Promise 的理解?可能是需要你能手动实现各个特性」•第 2 道「[每日一题]ES6 中为什么要使用 Symbol?」

2、浏览器

•第 9 题[每日一题]requestAnimationFrame不香吗?

3、Vue

•第 5 道「每日一题」到底该如何回答:vue数据绑定的实现原理?

4、React

•第 38 道【每日一题】(38题)谈谈React Hooks 与Vue3.0 Function based API的对比?

5、HTML5

•第 29 道【每日一题】(29题)面试官:HTML-HTML5新增标签属性的理解?

6、算法

•第 37 道【每日一题】(37题)面试官:你对图论了解多少?(七)•第 36 道【每日一题】(36题)面试官:你对图论了解多少?(六)•第 35 道【每日一题】(35题)面试官:你对图论了解多少?(五)•第 34 道【每日一题】(34题)面试官:你对图论了解多少?(四)•第 33 道【每日一题】(33题)面试官:你对图论了解多少?(三)•第 32 道【每日一题】(32题)面试官:你对图论了解多少?(二)•第 31 道[【每日一题】(31题)面试官:你对图论了解多少?(一)•第 27 道【每日一题】(27题)算法题:如何使用多种解决方案来实现跳一跳游戏?•第 26 道【每日一题】(26题)算法题:最长公共前缀?•第 25 道【每日一题】(25题)算法题:堆数据结构-前 K 个高频元素?•第 24 道【每日一题】(24题)算法题:贪心算法-环游世界之如何加油?•第 4 道「每日一题」与面试官手撕代码:如何科学高效的寻找重复元素?

7、Node

•第 23 道【每日一题】(23题)面试官问:详细描述事件循环Event Loop?

8、Http

•第 1 道「一道面试题是如何引发深层次的灵魂拷问?」•第 42 题【每日一题】(42题)谈谈你对Http2.0的理解?

  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot项目使用Spark 2.0,需要进行以下步骤: 1. 添加Spark依赖 在pom.xml文件添加以下依赖: ```xml <dependency> <groupId>org.apache.spark</groupId> <artifactId>spark-core_2.11</artifactId> <version>2.0.0</version> </dependency> ``` 2. 配置Spark环境 在Spring Boot项目,可以使用`SparkConf`类来配置Spark环境,如下所示: ```java @Configuration public class SparkConfig { @Bean public SparkConf sparkConf() { return new SparkConf() .setAppName("spring-boot-spark") .setMaster("local[*]"); } @Bean public JavaSparkContext sparkContext() { return new JavaSparkContext(sparkConf()); } } ``` 这里使用`@Configuration`注解创建一个Spark配置类,并且创建了一个`SparkConf`类的Bean,用于配置Spark环境。在上面的例子,我们设置了应用程序的名称为`spring-boot-spark`,并且使用本地模式运行Spark。 3. 编写Spark任务 在Spring Boot项目,可以使用Spring的`@Service`注解创建一个Spark任务类,例如: ```java @Service public class WordCountTask { @Autowired private JavaSparkContext sparkContext; public List<Tuple2<String, Integer>> countWords(String filePath) { JavaRDD<String> lines = sparkContext.textFile(filePath); JavaRDD<String> words = lines.flatMap(line -> Arrays.asList(line.split(" ")).iterator()); JavaPairRDD<String, Integer> wordCount = words.mapToPair(word -> new Tuple2<>(word, 1)).reduceByKey((a, b) -> a + b); return wordCount.collect(); } } ``` 在上面的例子,我们使用了Spark的API来读取一个文件,并统计每个单词出现的次数。这个任务会返回一个包含单词和出现次数的元组列表。 4. 调用Spark任务 在Spring Boot项目,可以使用Spring的`@RestController`注解创建一个RESTful API,用于调用Spark任务,例如: ```java @RestController @RequestMapping("/word-count") public class WordCountController { @Autowired private WordCountTask wordCountTask; @GetMapping("/{filePath}") public List<Tuple2<String, Integer>> countWords(@PathVariable String filePath) { return wordCountTask.countWords(filePath); } } ``` 在上面的例子,我们创建了一个`/word-count`的API,用于调用`WordCountTask`任务,并传入文件路径作为参数。 5. 运行应用程序 最后,可以使用Spring Boot的`@SpringBootApplication`注解创建一个启动类,用于运行整个应用程序,例如: ```java @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 在上面的例子,我们创建了一个`Application`类,并使用`SpringApplication.run`方法运行整个应用程序。 至此,在Spring Boot项目使用Spark 2.0的步骤就完成了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值