欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

nginx升級(jí)到支持HTTP2.0的方法示例

 更新時(shí)間:2019年07月25日 10:32:42   作者:saucxs  
這篇文章主要介紹了nginx升級(jí)到支持HTTP2.0的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、前言

最近想折騰一下服務(wù)器,升級(jí)到http2.0。

然后nginx照著官網(wǎng)配置了一下

    # ssl寫在443端口后面。這樣http和https的鏈接都可以用
    listen 443 ssl http2 default_server;
    server_name chat.chengxinsong.cn;
    
  # HSTS的合理使用,max-age表明HSTS在瀏覽器中的緩存時(shí)間,includeSubdomainscam參數(shù)指定應(yīng)該在所有子域上啟用HSTS,preload參數(shù)表示預(yù)加載,通過Strict-Transport-Security: max-age=0將緩存設(shè)置為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的共享內(nèi)存緩存,不同工作進(jìn)程共享TLS會(huì)話信息
  # ssl_session_cache shared:SSL:20m;
    
  # 設(shè)置會(huì)話緩存過期時(shí)間1h
  ssl_session_timeout 60m;
    
  # TLS協(xié)議的合理配置
  # 指定TLS協(xié)議的版本,不安全的SSL2和SSL3要廢棄掉
  ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    
  # 啟用ssl_prefer_server_ciphers,用來告訴Nginx在TLS握手時(shí)啟用服務(wù)器算法優(yōu)先,由服務(wù)器選擇適配算法而不是客戶端
  ssl_prefer_server_ciphers on;
    
  # 優(yōu)先選擇支持前向加密的算法,且按照性能的優(yōu)先順序排列
  ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    
  # 會(huì)話恢復(fù)的合理使用
  # 配置會(huì)話票證,減少了TLS握手的開銷
  ssl_session_tickets on;

然后執(zhí)行檢查nginx配置。nginx -t

意思就是說,http2.0缺少ngx_http_v2_module。nginx缺少http_ssl_module模塊,編譯安裝的時(shí)候帶上--with-http_ssl_module配置就行了。

二、查資料找原因

出現(xiàn)上面原因是nginx從1.9.5開始,已經(jīng)用 http_v2_module 模塊替換了 ngx_http_spdy_module ,并正式開始支持http2協(xié)議。

但是我的nginx是1.12.2。應(yīng)該不是ngin版本問題

注意事項(xiàng):

1、并且需要openssl庫的版本在1.0.2以上編譯。1.要開啟HTTP/2協(xié)議支持,需要在nginx 1.10以上版本并且需要openssl庫的版本在1.0.2以上編譯。

2.http2.0只支持開啟了https的網(wǎng)站。

可能是服務(wù)器的openssl庫的版本,發(fā)現(xiàn)是1.0.2。

所以還是要升級(jí)到更高點(diǎn)。

三、升級(jí)OpenSSL

在http2.0協(xié)議中,涉及到ALPN(Application Layer Protocol Negotiation,應(yīng)用層協(xié)議協(xié)商)的支持,目前所有主流的Unix服務(wù)器系統(tǒng)中內(nèi)置的OpenSSL庫都低于1.0.2版本。通過使用OpenSSL的命令行工具,可以檢查當(dāng)前的http2服務(wù)是否支持ALPN。

找一個(gè)安裝目錄

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
#顯示結(jié)果表明已升級(jí)到最新版本鏈接庫
OpenSSL 1.1.0f 25 May 2017

#配置openssl庫文件的搜索路徑
echo '/usr/local/openssl/lib' >> /etc/ld.so.conf
#使修改后的搜索路徑生效
ldconfig -v
#查看openssl版本,結(jié)果顯示升級(jí)成功
openssl version
OpenSSL 1.1.0f 25 May 2017

四、nginx開啟ssl模塊

默認(rèn)編譯的 Nginx 并不包含 h2 模塊,我們需要加入?yún)?shù)來編譯,截止發(fā)文,Nginx 1.9 開發(fā)版及以上版本源碼需要自己加入編譯參數(shù),從軟件源倉庫下載的則默認(rèn)編譯。 Nginx 是不再支持 SPDY。

如果你編譯的 Nginx 不支持,那么在 ./configure 中加入:--with-http_v2_module ,如果沒有 SSL 支持,還需要加入 --with-http_ssl_module

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

這時(shí)候需要去下載的時(shí)候的源碼文件夾中找到這個(gè)configure。注意:不是編譯之后的文件夾。

在"./configure"配置中,"--with"表示啟用模塊,也就是說這些模塊在編譯時(shí)不會(huì)自動(dòng)構(gòu)建"--without"表示禁用模塊,也就是說這些模塊在編譯時(shí)會(huì)自動(dòng)構(gòu)建,若你想Nginx輕量級(jí)運(yùn)行,可以去除一些不必要的模塊。

執(zhí)行./configure --help

從上圖知道了nginx在編譯時(shí)不會(huì)自動(dòng)構(gòu)建http_ssl_module和http_v2_module。所以需要重新編譯nginx。

2、加入?yún)?shù)編譯

我們的新配置信息就應(yīng)該這樣寫:

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

上面的/usr/local/nginx這個(gè)路徑是我們編譯之后的包路徑。

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

運(yùn)行上面的命令即可,等配置完

配置完成后,運(yùn)行命令

make

這里不要進(jìn)行make install,否則就是覆蓋安裝

3、備份和替換

(1)然后備份原有已安裝好的nginx

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

(2)關(guān)閉nginx,然后將剛剛編譯好的nginx覆蓋掉原有的nginx

關(guān)閉nginx

./nginx -s quit

移動(dòng)編譯好的nginx到原有的nginx

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

(3)啟動(dòng)nginx

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

五、查看網(wǎng)站是否是http2.0

右鍵name,勾選protocol,這樣就可以看到http協(xié)議。


上圖截圖網(wǎng)站地址:https://chat.chengxinsong.cn

對(duì)比一下http1.1的網(wǎng)站

上圖截圖網(wǎng)站地址:https://www.mwcxs.top

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Nginx中rewrite(地址重定向)的深入剖析

    Nginx中rewrite(地址重定向)的深入剖析

    Rewrite主要實(shí)現(xiàn)url地址重寫,以及url地址跳轉(zhuǎn),下面這篇文章主要給大家介紹了關(guān)于Nginx中rewrite(地址重定向)的深入剖析,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Nginx服務(wù)器添加Systemd自定義服務(wù)過程解析

    Nginx服務(wù)器添加Systemd自定義服務(wù)過程解析

    這篇文章主要介紹了Nginx服務(wù)器添加Systemd自定義服務(wù)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • linux上nginx安裝部署及使用過程詳解

    linux上nginx安裝部署及使用過程詳解

    這篇文章主要介紹了linux上nginx安裝部署及使用過程,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2019-11-11
  • CentOS系統(tǒng)rpm安裝Nginx和配置

    CentOS系統(tǒng)rpm安裝Nginx和配置

    大家好,本篇文章主要講的是CentOS系統(tǒng)rpm安裝Nginx和配置,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Nginx反向代理多域名的HTTP和HTTPS服務(wù)的實(shí)現(xiàn)

    Nginx反向代理多域名的HTTP和HTTPS服務(wù)的實(shí)現(xiàn)

    這篇文章主要介紹了Nginx反向代理多域名的HTTP和HTTPS服務(wù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • nginx中的正則表達(dá)式及l(fā)ocation和rewrite總結(jié)

    nginx中的正則表達(dá)式及l(fā)ocation和rewrite總結(jié)

    rewrite功能就是,使用nginx提供的全局變量或自己設(shè)置的變量,結(jié)合正則表達(dá)式和標(biāo)記位實(shí)現(xiàn)URL重寫以及重定向,這篇文章主要介紹了nginx中的正則表達(dá)式及l(fā)ocation和rewrite總結(jié),需要的朋友可以參考下
    2023-12-12
  • Nginx+Tomcat搭建高性能負(fù)載均衡集群的實(shí)現(xiàn)方法

    Nginx+Tomcat搭建高性能負(fù)載均衡集群的實(shí)現(xiàn)方法

    這篇文章主要介紹了Nginx+Tomcat搭建高性能負(fù)載均衡集群的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • Nginx 502 Bad Gateway錯(cuò)誤原因及解決方案

    Nginx 502 Bad Gateway錯(cuò)誤原因及解決方案

    這篇文章主要介紹了Nginx 502 Bad Gateway錯(cuò)誤原因及解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • nginx的zabbix 5.0安裝部署的方法步驟

    nginx的zabbix 5.0安裝部署的方法步驟

    之前大家可能經(jīng)常會(huì)基于apache去部署zabbix,但是這樣會(huì)偶爾遇到一些問題,今天小編就帶大家操作一下基于nginx的zabbix5.0的部署。感興趣的可以了解一下
    2021-07-07
  • nginx中g(shù)zip壓縮提升網(wǎng)站速度的實(shí)現(xiàn)方法

    nginx中g(shù)zip壓縮提升網(wǎng)站速度的實(shí)現(xiàn)方法

    這篇文章主要介紹了nginx中g(shù)zip壓縮提升網(wǎng)站速度的實(shí)現(xiàn)方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-08-08

最新評(píng)論