• 售前

  • 售后

热门帖子
入门百科

利用SSL设置Nginx反向署理的简单步调

[复制链接]
豆芽角角123 显示全部楼层 发表于 2021-10-26 12:42:45 |阅读模式 打印 上一主题 下一主题
媒介
反向代理是一个服务器,它吸收通过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. # 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. listen 80;
  3. return 301 https://$host$request_uri;
  4. }
  5. server {
  6. listen 443;
  7. server_name linuxtechlab.com;
  8. ssl_certificate /etc/nginx/ssl/cert.crt;
  9. ssl_certificate_key /etc/nginx/ssl/cert.key;
  10. ssl on;
  11. ssl_session_cache builtin:1000 shared:SSL:10m;
  12. ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  13. ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
  14. ssl_prefer_server_ciphers on;
  15. access_log /var/log/nginx/access.log;
  16. location / {
  17. proxy_set_header Host $host;
  18. proxy_set_header X-Real-IP $remote_addr;
  19. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  20. proxy_set_header X-Forwarded-Proto $scheme;
  21. proxy_pass http://localhost:8080;
  22. proxy_read_timeout 90;
  23. proxy_redirect http://localhost:8080 https://linuxtechlab.com;
  24. }
  25. }
复制代码
完成所有更改后,保存文件并退出。在我们重新启动nginx服务以实现所做的更改之前,我们将逐节讨论我们所做的配置。
第1节
  1. server {
  2. listen 80;
  3. return 301 https://$host$request_uri;
  4. }
复制代码
在这里,我们告诉我们要听取对端口80的任何哀求,然后将其重定向到https。
第2节
  1. listen 443;
  2. server_name linuxtechlab.com;
  3. ssl_certificate /etc/nginx/ssl/cert.crt;
  4. ssl_certificate_key /etc/nginx/ssl/cert.key;
  5. ssl on;
  6. ssl_session_cache builtin:1000 shared:SSL:10m;
  7. ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  8. ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
  9. ssl_prefer_server_ciphers on;
复制代码
现在这些是我们正在利用的一些默认的nginx ssl选项,它们告诉nginx web服务器支持哪种协议版本,SSL暗码。
第3节
  1. location / {
  2. proxy_set_header Host $host;
  3. proxy_set_header X-Real-IP $remote_addr;
  4. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  5. proxy_set_header X-Forwarded-Proto $scheme;
  6. proxy_pass http://localhost:8080;
  7. proxy_read_timeout 90;
  8. proxy_redirect http://localhost:8080 https://linuxtechlab.com;
  9. }
复制代码
现在,本节先容代理以及传入哀求进入后的位置。现在我们已经讨论了所有配置,我们将检查然后重新启动nginx服务。
要检查nginx,请运行以下命令
  1. # nginx -t
复制代码
一旦我们所有配置文件都ok,我们将重新启动nginx服务
  1. # systemctl restart nginx
复制代码
就是如许,我们的ssl nginx反向代理现已准备停当。现在要测试设置,您所要做的就是打开Web欣赏器并输入URL。我们现在应该重定向到apache tomcat网页。
这完成了我们如何利用ssl配置nginx反向代理的教程
总结
以上就是这篇文章的全部内容了,希望本文的内容对各人的学习或者工作具有肯定的参考学习价值,谢谢各人对脚本之家的支持。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作