1.前言
最近在優化網站的訪問速度,為網站開啟http2協議,這個協議有什么優點呢?如下:
- http2是下一代的傳輸協議,以后都會普遍用它,是一個趨勢。
- http2有多路復用特性,意思是訪問一個域名下面的資源,多個請求共用一條TCP鏈路,所以比http1.1要快得多。
2.準備工作
- 需要重新編譯openssl1.0.2以上版本,因為我們系統的版本都是centos6的,不支持直接yum更新openssl,如果是centos7,直接yum update openssl -y 即可更新
- 編譯完成openssl后,需要重新使用openssl的庫文件重新編譯Tenginx,我們使用的Tengine版本是Tengine/2.2.2。
3.操作步驟
- 安裝 openssl-1.0.2t
#進入/usr/local/src,一般軟件包都放這里
cd /usr/local/src
#下載安裝包
wget https://www.openssl.org/source/openssl-1.0.2t.tar.gz
tar -zxvf openssl-1.0.2t.tar.gz
cd openssl-1.0.2t
./config shared zlib
#默認安裝找/usr/local/ssl
make && make install
#先備份之前的老版本
mv /usr/bin/openssl /usr/bin/openssl.old
mv /usr/include/openssl /usr/include/openssl.old
#建立軟連接
ln -s /usr/local/ssl/bin/openssl /usr/bin/openssl
ln -s /usr/local/ssl/include/openssl /usr/include/openssl
#把動態庫加入系統配置路徑
echo "/usr/local/ssl/lib" >> /etc/ld.so.conf
#查看動態庫是否生效
ldconfig -p
#檢查openssl版本
openssl version
- 安裝Tenginx
cd /usr/local/src
wget http://tengine.taobao.org/download/tengine-2.2.2.tar.gz
tar tengine-2.2.2.tar.gz
cd tengine-2.2.2
#這里需要修改一下tengine的代碼,因為我們是手動編譯的openssl,依賴庫路徑和原來系統安裝的不太一樣,所以需要手動指定
vim auto/lib/openssl/conf
#在大概32行配置原來配置如下:
CORE_INC
CORE_DEP
CORE_LIB
CORE_LIB
#修改成如下,保存退出
CORE_INC
CORE_DEP
CORE_LIB
CORE_LIB
#先安裝一些依賴(我是升級,其實不需要安裝依賴了,如果是首次安裝tenginx,就需要安裝依賴)
yum -y install zlib zlib-devel openssl openssl-devel pcre pcre-devel gcc gcc-c++ autoconf automake jemalloc jemalloc-devel
#開始編譯tenginx
cd /usr/local/src/tengine-2.2.2 && ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_gzip_static_module --with-http_concat_module --with-jemalloc --with-http_v2_module --with-http_secure_link_module --with-openssl=/usr/local/ssl
make
##注意,如果是第一安裝tegninx,只需要只需執行以下命令
make install
#但是我是安裝過了,所以需要備份老的tenginx
cp -af /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx_bak
cp -af /usr/local/nginx/sbin/dso_tool /usr/local/nginx/sbin/dso_tool_bak
#拷貝編譯好的tenginx到對應目錄
cp /usr/local/src/tengine-2.2.2/objs/nginx /usr/local/nginx/sbin/
cp /usr/local/src/tengine-2.2.2/objs/dso_tool /usr/local/nginx/sbin/
#然后重啟Tenginx,就算編譯安裝完成啦
- Tenginx http2配置
#配置http2很簡單,如下:
server {
#http 不支持http2的傳輸協議,所以80端口不變
listen 80
# listen在原https配置文件基礎上添加http2
listen 443 ssl http2;
server_name www.oneq.work;
.....
}
#另外附上一份完整的支持http2的Tenginx配置
upstream server_backend {
server ip:80 weight=10;
server ip:80 weight=10;
keepalive 800;
#下面檢測端口的配置需要Tenginx的才有效,不是Tenginx需要安裝額外的插件或者直接注釋即可
check interval=5000 rise=3 fall=3 timeout=5000 type=tcp;
}
server {
listen 80;
listen 443 ssl http2;
server_name xxx.xxx.xxx;
req_status server;
ssl_certificate /usr/local/nginx/certs/xxx.xxx.xxx.crt;
ssl_certificate_key /usr/local/nginx/certs/xxx.xxx.xxx.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1.1 TLSv1.2 TLSv1;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass_header User-Agent;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Connection "";
proxy_http_version 1.1;
access_log logs/access.log main;
location / {
proxy_pass http://server_backend/;
access_log logs/server_backend.log main;
}
error_page 404 /404.html;
location = /404.html {
root html;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
4.效果展示
5.總結
1.第一次安裝tenginx和升級步驟有所區別,需要注意下
2.http不支持http2的傳輸協議,所以80端口還是使用http1.1的協議,https使用http2的傳輸協議
作者博客 青葉的博客
審核編輯 黃昊宇
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
Linux
+關注
關注
87文章
11322瀏覽量
209864 -
OpenSSL
+關注
關注
0文章
21瀏覽量
8705 -
nginx
+關注
關注
0文章
151瀏覽量
12189 -
http2.0
+關注
關注
0文章
3瀏覽量
2144 -
Tengine
+關注
關注
1文章
47瀏覽量
2862
發布評論請先 登錄
相關推薦
如何使用 cURL 測試 HTTP 協議
cURL是一個強大的命令行工具,用于傳輸數據,支持多種協議,包括HTTP、HTTPS、FTP等。使用cURL測試HTTP協議可以幫助你理解
HTTP 1.1 和 HTTP 2.0 的區別
HTTP(超文本傳輸協議)是互聯網上應用最為廣泛的協議之一,用于在客戶端和服務器之間傳輸數據。隨著技術的發展,
如何使用 HTTP 協議進行數據傳輸
在互聯網時代,數據傳輸是信息交換的基礎。HTTP協議作為最常用的數據傳輸協議之一,支撐著全球數十億用戶的數據交互。
HTTP 協議的基本概念
HTTP(HyperText Transfer Protocol,超文本傳輸協議)是一種用于分布式、協作式、超媒體信息系統的網絡協議。HTTP
socket 與 HTTP 協議的關系
在計算機網絡中,Socket和HTTP協議是兩個非常重要的概念,它們在數據傳輸和網絡通信中扮演著關鍵的角色。 1. Socket的概念 Socket是一種通信機制,它允許兩個程序(一個客戶端和一個
socket與HTTP協議的比較
在計算機網絡中,Socket和HTTP協議都是非常重要的概念。它們在數據傳輸和通信中扮演著關鍵角色,但它們的應用場景和工作原理有所不同。 1. 定義與基本概念 1.1 Socket Socket
4G 模組 HTTP 網絡協議應用 白嫖版!
今天我們來白嫖的是Air780E模組LuatOS開發4G通信中HTTP網絡協議的應用,實現模組和服務器之間數據的傳輸,詳細介紹硬件環境、軟件環境、功能驗證等…
HTTP協議下的海外網絡暢游:安全與效率的雙重保障
在全球化日益加深的今天,HTTP協議作為互聯網上最為廣泛使用的通信協議之一,為海外網絡暢游提供了重要的技術支持。在HTTP協議下,海外網絡暢
mqtt協議和http協議區別
的最大優點在于,用極少的代碼和有限的帶寬,為連接遠程設備提供實時可靠的消息服務。 HTTP協議(HyperText Transfer Protocol)是因特網上應用最為廣泛的一種網絡傳輸協議
評論