当前位置: 首页 > news >正文

Nginx系列09(Nginx 与其他服务集成、实战项目)

目录

Nginx 与其他服务集成

实战项目


Nginx 与其他服务集成

  • Nginx 与 Tomcat 集成
    • 概念:将 Nginx 作为前端代理服务器,Tomcat 作为后端应用服务器。Nginx 负责处理静态资源请求、负载均衡以及将动态请求转发给 Tomcat,Tomcat 则专注于运行 Java Web 应用程序,如 Servlet、JSP 等。
    • 原理:Nginx 通过proxy_pass指令将匹配的请求转发到 Tomcat 服务器的特定端口(默认 8080)。同时,为了确保 Tomcat 能正确处理请求,需要在 Nginx 配置中设置一些请求头信息,如HostX - Real - IP等。
    • 场景示例:假设你有一个 Java Web 应用,打包成 WAR 文件并部署在 Tomcat 服务器上。你希望通过 Nginx 实现对该应用的访问,并利用 Nginx 的负载均衡和静态资源处理能力。
      • Tomcat 配置:确保 Tomcat 正常运行,并且你的 Java Web 应用已成功部署在 Tomcat 的webapps目录下。假设应用上下文路径为/myapp
      • Nginx 配置
http {
    upstream tomcat_servers {
        server 127.0.0.1:8080; # 假设Tomcat运行在本地8080端口
    }
    server {
        listen 80;
        server_name example.com;
        location /myapp {
            proxy_pass http://tomcat_servers/myapp;
            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;
        }
        location /static {
            root /path/to/your/static/files; # 假设静态资源存放在此路径
            expires 30d;
        }
    }
}

在这个配置中,upstream块定义了 Tomcat 服务器的地址。location /myapp块将以/myapp开头的请求转发给 Tomcat 服务器,同时设置了必要的请求头。location /static块用于处理静态资源请求,直接从指定路径读取并返回静态文件,同时设置了缓存过期时间为 30 天。

  • Nginx 与 Redis 集成
    • 概念:Nginx 与 Redis 集成主要用于利用 Redis 的缓存功能来加速 Nginx 的响应。Redis 可以缓存 Nginx 处理的频繁访问的数据或页面片段,减少对后端服务器的请求,提高网站性能。
    • 原理:Nginx 通过ngx_http_redis_module模块(需编译安装)与 Redis 进行交互。当 Nginx 接收到请求时,先检查 Redis 中是否存在缓存数据。如果存在,则直接返回缓存数据;否则,Nginx 处理请求,将结果存入 Redis 缓存,并返回给客户端。
    • 场景示例:假设你有一个新闻网站,新闻列表页面更新频率较低,但访问量很大。你希望通过 Nginx 与 Redis 集成来缓存新闻列表页面,减少数据库查询压力。
      • Redis 安装与配置:安装 Redis 并确保其正常运行。
      • Nginx 配置:首先编译安装 Nginx 并添加ngx_http_redis_module模块。然后进行如下配置:
http {
    lua_package_path "/path/to/lua/?.lua;;"; # 如果使用Lua脚本与Redis交互,设置Lua脚本路径
    server {
        listen 80;
        server_name news.example.com;
        location /news/list {
            set $redis_key "news_list";
            redis2_query GET $redis_key;
            redis2_pass 127.0.0.1:6379; # 假设Redis运行在本地6379端口
            if ($redis2_reply) {
                return 200 $redis2_reply;
            }
            # 如果Redis中没有缓存,处理请求并缓存结果
            proxy_pass http://backend_news_server/news/list;
            set $response_body $upstream_output_body;
            redis2_query SET $redis_key $response_body EX 3600; # 缓存结果到Redis,有效期1小时
            return 200 $response_body;
        }
    }
}

在这个配置中,location /news/list块处理新闻列表页面请求。首先尝试从 Redis 中获取缓存数据(redis2_query GET $redis_key;),如果获取到则直接返回(return 200 $redis2_reply;)。如果未获取到,则将请求转发到后端新闻服务器(proxy_pass http://backend_news_server/news/list;),获取响应后将响应体缓存到 Redis(redis2_query SET $redis_key $response_body EX 3600;),并返回给客户端。

实战项目

  • 项目场景:假设要将一个 Django 项目部署到 Nginx 服务器上,并实现虚拟主机配置、反向代理、负载均衡(假设后端有多个 Django 应用实例)、缓存以及安全配置。
  • 项目步骤
    • Django 项目准备:确保 Django 项目已开发完成,并且项目的settings.py文件中配置了正确的ALLOWED_HOSTS,例如ALLOWED_HOSTS = ['example.com']
    • Nginx 安装与配置
      • 虚拟主机配置
http {
    server {
        listen 80;
        server_name example.com;
        # 其他配置...
    }
}
  • 反向代理:假设 Django 项目运行在127.0.0.1:8000,配置如下:
http {
    server {
        listen 80;
        server_name example.com;
        location / {
            proxy_pass http://127.0.0.1:8000;
            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;
        }
    }
}
  • 负载均衡:假设后端有两个 Django 应用实例,分别运行在127.0.0.1:8000127.0.0.1:8001,配置如下:
http {
    upstream django_servers {
        server 127.0.0.1:8000;
        server 127.0.0.1:8001;
    }
    server {
        listen 80;
        server_name example.com;
        location / {
            proxy_pass http://django_servers;
            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;
        }
    }
}
  • 缓存配置:配置代理缓存,对 Django 应用的响应进行缓存,例如:
http {
    proxy_cache_path /data/nginx/cache levels=1:2 keys_zone=my_cache:10m max_size=10g inactive=60m use_temp_path=off;
    server {
        listen 80;
        server_name example.com;
        location / {
            proxy_pass http://django_servers;
            proxy_cache my_cache;
            proxy_cache_key "$uri$is_args$args";
            proxy_cache_valid 200 60m;
            proxy_cache_bypass $http_pragma $http_authorization;
            proxy_cache_revalidate on;
        }
    }
}
  • 安全配置:设置访问控制,只允许特定 IP 地址访问,例如:
http {
    server {
        listen 80;
        server_name example.com;
        location / {
            deny all;
            allow 192.168.1.0/24; # 假设允许的IP地址段
        }
    }
}

通过以上步骤,完成了 Django 项目在 Nginx 服务器上的部署,并实现了多种功能的配置,提升了项目的性能和安全性。在实际项目中,可能还需要根据具体需求进行更多的优化和调整。

相关文章:

  • 机器学习:线性回归,梯度下降
  • freertos 学习5--链路状态设置
  • 房屋租赁|房屋租赁系统|基于Springboot的房屋租赁系统设计与实现(源码+数据库+文档)
  • k8s出问题后 应该查看哪些内容
  • QT基础十、表格组件:QTableWidget
  • Text-to-SQL将自然语言转换为数据库查询语句
  • 【网络安全】敏感字段扫描工具(可用于漏洞挖掘、代码审计)
  • 为什么深度学习选择Tensor而非NumPy数组?核心优势深度解析
  • 两道算法练习
  • 论文笔记-NeurIPS2017-DropoutNet
  • 一周一个Unity小游戏2D反弹球游戏 - 球的死区及球重生
  • SpringBoot新闻推荐系统设计与实现
  • AtCoder Beginner Contest 395 题解ABCDEF
  • android studio gradle 阿里镜像
  • Java基础语法练习34(抽象类-abstract)(抽象类最佳实践-模版设计模式)
  • 智能图像处理平台:图像处理配置类
  • Jenkins 自动打包项目镜像部署到服务器 ---(前端项目)
  • 算法教程:岛的最大面积
  • RabbitMQ系列(零)概要
  • React底层原理详解
  • 护肤品网站建设目的/网络推广的基本渠道
  • 徐家汇网站建设/网站设计模板
  • 购物网站开发教程 视频/seo诊断分析报告
  • 网站佣金怎么做会计科目/域名查询网址
  • 营销型企业网站建设/营销平台有哪些
  • dede网站限制IP浏览/济宁百度推广公司