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

目录

[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 配置
bash 复制代码
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模块。然后进行如下配置:
bash 复制代码
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 安装与配置
      • 虚拟主机配置
bash 复制代码
http {
    server {
        listen 80;
        server_name example.com;
        # 其他配置...
    }
}
  • 反向代理 :假设 Django 项目运行在127.0.0.1:8000,配置如下:
bash 复制代码
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,配置如下:
bash 复制代码
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 应用的响应进行缓存,例如:
bash 复制代码
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 地址访问,例如:
bash 复制代码
http {
    server {
        listen 80;
        server_name example.com;
        location / {
            deny all;
            allow 192.168.1.0/24; # 假设允许的IP地址段
        }
    }
}

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

相关推荐
道法自然,人法天1 分钟前
微服务学习(4):RabbitMQ中交换机的应用
运维·学习·docker·微服务·rabbitmq
刘翔在线犯法9 分钟前
虚拟机IP的配置,让它上网
linux·运维·服务器
m0_7482309410 分钟前
详解Nginx no live upstreams while connecting to upstream
运维·nginx
西域编娃1 小时前
CentOS 7 IP 地址设置保姆级教程
linux·运维·centos
小han的日常1 小时前
UI自动化框架介绍
运维·ui·自动化
赵民勇2 小时前
debian/control文件中的${shlibs:Depends}
linux·运维·debian
佛州小李哥2 小时前
我代表中国受邀在亚马逊云科技全球云计算大会re:Invent中技术演讲
运维·人工智能·科技·云计算·aws·云安全·亚马逊云科技
Htht1113 小时前
【Linux】之【Bug】VMware 虚拟机开机 一直卡在黑屏左上角下划线闪烁界面
linux·运维·bug
溟洵3 小时前
Linux下学【MySQL】表的连接(inner join、left join、right join)(简单试题理解版)
linux·运维·mysql
健康平安的活着4 小时前
性能调优-cpu的性能指标【经典篇】
linux·运维·服务器