溫馨提示×

溫馨提示×

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

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

如何利用SSL配置Nginx反向代理

發(fā)布時間:2022-05-21 10:49:51 來源:億速云 閱讀:666 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要介紹“如何利用SSL配置Nginx反向代理”的相關(guān)知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“如何利用SSL配置Nginx反向代理”文章能幫助大家解決問題。

先決條件

1.后端服務(wù)器:為了本教程的目的,我們使用在端口8080的localhost上運行的tomcat服務(wù)器

注意: - 當(dāng)您開始代理請求時,請確保應(yīng)用程序服務(wù)器已啟動。

2.ssl證書:我們還需要在服務(wù)器上配置ssl證書。我們可以使用 let's encrypt的加密證書,你可以使用這里提到的程序得到一個。但是對于本教程,我們將使用自簽名證書,可以通過從終端運行以下命令來創(chuàng)建,

$ openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/nginx/certs/cert.key -out /etc/nginx/certs/cert.crt

使用ssl配置nginx反向代理的下一步將是nginx安裝,

安裝nginx

ubuntu

nginx可用于默認(rèn)的ubuntu存儲庫。這么簡單,使用以下命令安裝它,

$ sudo apt-get update && sudo apt-get install nginx

現(xiàn)在啟動服務(wù)并啟用它以進行啟動,

# systemctl start nginx 
 
# systemctl enable nginx

現(xiàn)在檢查nginx安裝,我們可以打開web瀏覽器并輸入系統(tǒng)ip作為url以獲取默認(rèn)的nginx網(wǎng)頁,這確認(rèn)nginx工作正常。

使用ssl配置nginx反向代理

現(xiàn)在我們擁有了使用ssl配置nginx反向代理所需的所有東西。我們現(xiàn)在需要在nginx中進行配置,我們將使用默認(rèn)的nginx配置文件,即/etc/nginx/conf.d/default.conf.

假設(shè)這是我們第一次對配置進行任何更改,打開文件并刪除或注釋所有舊文件內(nèi)容,然后將以下條目放入文件中。

vi /etc/nginx/conf.d/default.conf

server { 
 
listen 80; 
 
return 301 https://$host$request_uri; 
 
} 
 
 
 
 
server { 
 
listen 443; 
 
server_name linuxtechlab.com; 
 
ssl_certificate /etc/nginx/ssl/cert.crt; 
 
 
 
 
ssl_certificate_key /etc/nginx/ssl/cert.key; 
 
ssl on; 
 
ssl_session_cache builtin:1000 shared:ssl:10m; 
 
ssl_protocols tlsv1 tlsv1.1 tlsv1.2; 
 
ssl_ciphers high:!anull:!enull:!export:!camellia:!des:!md5:!psk:!rc4; 
 
ssl_prefer_server_ciphers on; 
 
access_log /var/log/nginx/access.log; 
 
 
 
 
location / { 
 
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_set_header x-forwarded-proto $scheme; 
 
proxy_pass http://localhost:8080; 
 
proxy_read_timeout 90; 
 
proxy_redirect http://localhost:8080 https://linuxtechlab.com; 
 
} 
 
}

完成所有更改后,保存文件并退出。在我們重新啟動nginx服務(wù)以實現(xiàn)所做的更改之前,我們將逐節(jié)討論我們所做的配置。

第1節(jié)

server { 
listen 80; 
return 301 https://$host$request_uri; 
}

在這里,我們告訴我們要聽取對端口80的任何請求,然后將其重定向到https。

第2節(jié)

listen 443; 
 
server_name linuxtechlab.com; 
 
ssl_certificate /etc/nginx/ssl/cert.crt; 
 
ssl_certificate_key /etc/nginx/ssl/cert.key; 
 
ssl on; 
 
ssl_session_cache builtin:1000 shared:ssl:10m; 
 
ssl_protocols tlsv1 tlsv1.1 tlsv1.2; 
 
ssl_ciphers high:!anull:!enull:!export:!camellia:!des:!md5:!psk:!rc4; 
 
ssl_prefer_server_ciphers on;

現(xiàn)在這些是我們正在使用的一些默認(rèn)的nginx ssl選項,它們告訴nginx web服務(wù)器支持哪種協(xié)議版本,ssl密碼。

第3節(jié)

location / { 
 
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_set_header x-forwarded-proto $scheme; 
 
proxy_pass http://localhost:8080; 
 
proxy_read_timeout 90; 
 
proxy_redirect http://localhost:8080 https://linuxtechlab.com; 
 
}

現(xiàn)在,本節(jié)介紹代理以及傳入請求進入后的位置。現(xiàn)在我們已經(jīng)討論了所有配置,我們將檢查然后重新啟動nginx服務(wù)。

要檢查nginx,請運行以下命令

# nginx -t

一旦我們所有配置文件都o(jì)k,我們將重新啟動nginx服務(wù)

# systemctl restart nginx

就是這樣,我們的ssl nginx反向代理現(xiàn)已準(zhǔn)備就緒。現(xiàn)在要測試設(shè)置,您所要做的就是打開web瀏覽器并輸入url。我們現(xiàn)在應(yīng)該重定向到apache tomcat網(wǎng)頁。

關(guān)于“如何利用SSL配置Nginx反向代理”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點。

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

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

AI