|
|
51CTO旗下网站
|
|
移动端

使用SSL配置Nginx反向代理的简单指南

反向代理是一个服务器,它接收通过Web发出的请求,即http和https,然后将它们发送到后端服务器(或服务器)。后端服务器可以是单个或一组应用服务器,如Tomcat,wildfly或Jenkins等,或者甚至可以是其他Web服务器,如Apache等。

作者:程序猿knight来源:程序猿knight|2019-05-22 14:42

【大咖·来了 第7期】10月24日晚8点观看《智能导购对话机器人实践》

反向代理是一个服务器,它接收通过Web发出的请求,即http和https,然后将它们发送到后端服务器(或服务器)。后端服务器可以是单个或一组应用服务器,如Tomcat,wildfly或Jenkins等,或者甚至可以是其他Web服务器,如Apache等。

我们已经讨论过如何使用Nginx配置简单的http反向代理。在本教程中,我们将讨论如何使用SSL配置Nginx反向代理。因此,让我们从使用SSL配置Nginx反向代理的过程开始。

先决条件

1.后端服务器:为了本教程的目的,我们使用在端口8080的localhost上运行的tomcat服务器

注意: - 当您开始代理请求时,请确保应用程序服务器已启动。

2.SSL证书:我们还需要在服务器上配置SSL证书。我们可以使用 let’s encrypt的加密证书,你可以使用这里提到的程序得到一个。但是对于本教程,我们将使用自签名证书,可以通过从终端运行以下命令来创建,

  1. $ 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可用于默认的Ubuntu存储库。这么简单,使用以下命令安装它,

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

现在启动服务并启用它以进行启动,

  1. # systemctl start nginx 
  2.  
  3. # systemctl enable nginx 

现在检查nginx安装,我们可以打开Web浏览器并输入系统IP作为url以获取默认的nginx网页,这确认nginx工作正常。

使用SSL配置Nginx反向代理

现在我们拥有了使用ssl配置nginx反向代理所需的所有东西。我们现在需要在nginx中进行配置,我们将使用默认的nginx配置文件,即/etc/nginx/conf.d/default.conf.

假设这是我们第一次对配置进行任何更改,打开文件并删除或注释所有旧文件内容,然后将以下条目放入文件中。

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

  1. server { 
  2.  
  3. listen 80; 
  4.  
  5. return 301 https://$host$request_uri; 
  6.  
  7.  
  8.  
  9.  
  10.  
  11. server { 
  12.  
  13. listen 443; 
  14.  
  15. server_name linuxtechlab.com; 
  16.  
  17. ssl_certificate /etc/nginx/ssl/cert.crt; 
  18.  
  19.  
  20.  
  21.  
  22. ssl_certificate_key /etc/nginx/ssl/cert.key
  23.  
  24. ssl on
  25.  
  26. ssl_session_cache builtin:1000 shared:SSL:10m; 
  27.  
  28. ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 
  29.  
  30. ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4; 
  31.  
  32. ssl_prefer_server_ciphers on
  33.  
  34. access_log /var/log/nginx/access.log; 
  35.  
  36.  
  37.  
  38.  
  39. location / { 
  40.  
  41. proxy_set_header Host $host; 
  42.  
  43. proxy_set_header X-Real-IP $remote_addr; 
  44.  
  45. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  46.  
  47. proxy_set_header X-Forwarded-Proto $scheme; 
  48.  
  49. proxy_pass http://localhost:8080; 
  50.  
  51. proxy_read_timeout 90; 
  52.  
  53. proxy_redirect http://localhost:8080 https://linuxtechlab.com; 
  54.  
  55.  

完成所有更改后,保存文件并退出。在我们重新启动nginx服务以实现所做的更改之前,我们将逐节讨论我们所做的配置。

第1节

  1. server { 
  2. listen 80;  
  3. return 301 https://$host$request_uri; 

在这里,我们告诉我们要听取对端口80的任何请求,然后将其重定向到https。

第2节

  1. listen 443; 
  2.  
  3. server_name linuxtechlab.com; 
  4.  
  5. ssl_certificate /etc/nginx/ssl/cert.crt; 
  6.  
  7. ssl_certificate_key /etc/nginx/ssl/cert.key
  8.  
  9. ssl on
  10.  
  11. ssl_session_cache builtin:1000 shared:SSL:10m; 
  12.  
  13. ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 
  14.  
  15. ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4; 
  16.  
  17. ssl_prefer_server_ciphers on

现在这些是我们正在使用的一些默认的nginx ssl选项,它们告诉nginx web服务器支持哪种协议版本,SSL密码。

第3节

  1. location / { 
  2.  
  3. proxy_set_header Host $host; 
  4.  
  5. proxy_set_header X-Real-IP $remote_addr; 
  6.  
  7. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  8.  
  9. proxy_set_header X-Forwarded-Proto $scheme; 
  10.  
  11. proxy_pass http://localhost:8080; 
  12.  
  13. proxy_read_timeout 90; 
  14.  
  15. proxy_redirect http://localhost:8080 https://linuxtechlab.com; 
  16.  

现在,本节介绍代理以及传入请求进入后的位置。现在我们已经讨论了所有配置,我们将检查然后重新启动nginx服务。

要检查nginx,请运行以下命令

  1. # nginx -t 

一旦我们所有配置文件都ok,我们将重新启动nginx服务

  1. # systemctl restart nginx 

就是这样,我们的ssl nginx反向代理现已准备就绪。现在要测试设置,您所要做的就是打开Web浏览器并输入URL。我们现在应该重定向到apache tomcat网页。

这完成了我们如何使用ssl配置nginx反向代理的教程,请使用下面的注释框发送有关本教程的任何问题或疑问。

【编辑推荐】

  1. Netcraft 4月Web服务器排名:Nginx首度登上第一宝座
  2. Nginx成为4月市占率最高的Web服务器
  3. 懂点 Nginx 反向代理与负载均衡,是面试加分项没有之一
  4. Nginx+Tomcat会话保持N种方案,各有千秋!你选择对了吗?
  5. 一段万能的Nginx接口实现反向代理配置值得收藏!
【责任编辑:武晓燕 TEL:(010)68476606】


点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

Spring Boot 爬虫搜索轻松游

Spring Boot 爬虫搜索轻松游

全栈式开发之旅
共4章 | 美码师

51人订阅学习

Linux性能调优攻略

Linux性能调优攻略

性能调优规范
共15章 | 南非蚂蚁

181人订阅学习

VMware vSphere虚拟化常见故障

VMware vSphere虚拟化常见故障

搞定vSphere虚拟化
共18章 | 王春海

71人订阅学习

读 书 +更多

数据挖掘:概念与技术

本书第1版曾被KDnuggets的读者评选为最受欢迎的数据挖掘专著,是一本可读性极佳的教材。它从数据库角度全面系统地介绍了数据挖掘的基本概念...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO播客