溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么升級nginx支持HTTP/2服務(wù)端推送

發(fā)布時(shí)間:2022-04-27 14:11:19 來源:億速云 閱讀:156 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容介紹了“怎么升級nginx支持HTTP/2服務(wù)端推送”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

升級nginx到1.14.0

1、配置nginx官方的yum源。創(chuàng)建配置文件 /etc/yum.repos.d/nginx.repo ,寫入如下內(nèi)容

[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1

2、更新nginx

yum update

3、重啟nginx

systemctl restart nginx

4、驗(yàn)證nginx版本

$ curl -i 127.0.0.1
http/1.1 301 moved permanently
server: nginx/1.14.0

修改nginx配置

在原有的配置上,加上 http2_push_preload on; 。當(dāng)nginx檢測到 link 響應(yīng)首部時(shí),會主動往客戶端推送資源。

location ~ \.php$ {
  # ...省略其他配置
  http2_push_preload on; # 加上這行
}

修改wordpress主題

nginx的 http2_push_preload 需要應(yīng)用服務(wù)的配合。比如我要主動推送 index.js 這個(gè)文件,那么需要加上如下響應(yīng)首部:

link: </index.js>; as=script; rel=preload

也可以同時(shí)推送多個(gè)文件,比如:

link: </index.js>; as=script; rel=preload, </index.css>; as=style; rel=preload

具體到wordpress,可以加上如下代碼:

function add_http2_push_header() {
  $preload_resource_array = array(
    '</index.js>; as=script; rel=preload',
    '</index.css>; as=style; rel=preload'
  );
  $preload_link_value = join( ', ', $preload_resource_array );

  header( 'link: '.$preload_link_value ); 
}
add_action( 'send_headers', 'add_http2_push_header' );

瀏覽器驗(yàn)證

升級之前,不支持服務(wù)端推送。

怎么升級nginx支持HTTP/2服務(wù)端推送

升級之后,支持服務(wù)端推送。

怎么升級nginx支持HTTP/2服務(wù)端推送 

“怎么升級nginx支持HTTP/2服務(wù)端推送”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI