NGINX配置详解

简介: NGINX配置详解

NGINX 是一个高性能的HTTP和反向代理服务器,广泛应用于Web服务器和反向代理服务。它不仅具备高效的静态内容处理能力,还支持动态内容的反向代理及负载均衡。本文将深入解析NGINX的配置文件,并提供多种配置示例,每个示例都包含详细注释,以帮助大家更好地理解和使用NGINX。

NGINX 配置文件结构

NGINX 的配置文件通常位于 /etc/nginx/nginx.conf,主要包含以下几个部分:

  1. 全局设置
  2. HTTP设置
  3. Server块
  4. Location块

全局设置

全局设置位于配置文件的顶层,定义了NGINX的工作进程数、用户权限、错误日志路径等全局性配置。

user nginx; # 运行NGINX服务的用户
worker_processes auto; # 工作进程数,通常设为CPU核心数
error_log /var/log/nginx/error.log; # 错误日志路径
pid /run/nginx.pid; # 存放NGINX进程ID的文件

HTTP 设置

HTTP设置包含多个server块,定义了HTTP相关的全局配置,如连接超时、文件包含、Gzip压缩等。

http {
    include /etc/nginx/mime.types; # 文件扩展名与文件类型映射表
    default_type application/octet-stream; # 默认文件类型
    log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"'; # 日志格式
    access_log /var/log/nginx/access.log main; # 访问日志路径及格式
    sendfile on; # 开启高效文件传输模式
    keepalive_timeout 65; # 连接保持超时时间
    include /etc/nginx/conf.d/*.conf; # 包含其他配置文件
}

Server 块

Server块定义了虚拟主机的配置,包含监听端口、域名、SSL证书等设置。

server {
    listen 80; # 监听端口
    server_name example.com www.example.com; # 服务器名称,可以是域名或IP
 
    location / {
        root /usr/share/nginx/html; # 网站根目录
        index index.html index.htm; # 默认首页文件
    }
 
    error_page 404 /404.html; # 自定义404页面
    location = /40x.html {
    }
 
    error_page 500 502 503 504 /50x.html; # 自定义50x错误页面
    location = /50x.html {
    }
}

Location 块

Location块用于匹配请求的URI,并根据匹配结果进行相应的处理。

server {
    listen 80;
    server_name example.com;
 
    location / {
        root /usr/share/nginx/html;
        index index.html index.htm;
    }
 
    location /images/ {
        alias /data/images/; # 将/images/映射到/data/images/目录
    }
 
    location ~* \.(jpg|jpeg|png|gif|ico)$ {
        expires 30d; # 设置缓存过期时间
    }
}

示例配置

示例1:简单的反向代理

将请求代理到后端服务器。

server {
    listen 80;
    server_name proxy.example.com;
 
    location / {
        proxy_pass http://backend.example.com; # 将请求代理到后端服务器
        proxy_set_header Host $host; # 设置请求头
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

示例2:负载均衡

将请求分配到多台后端服务器,实现负载均衡。

http {
    upstream backend {
        server backend1.example.com weight=3; # 后端服务器1,权重为3
        server backend2.example.com weight=2; # 后端服务器2,权重为2
        server backend3.example.com; # 后端服务器3,权重为1(默认)
    }
 
    server {
        listen 80;
        server_name loadbalancer.example.com;
 
        location / {
            proxy_pass http://backend; # 将请求代理到后端服务器组
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
    }
}

示例3:SSL 配置

启用SSL并配置HTTPS访问。

server {
    listen 443 ssl; # 监听443端口,启用SSL
    server_name ssl.example.com;
 
    ssl_certificate /etc/nginx/ssl/example.com.crt; # SSL证书
    ssl_certificate_key /etc/nginx/ssl/example.com.key; # SSL证书密钥
    ssl_protocols TLSv1.2 TLSv1.3; # 允许的SSL协议
    ssl_ciphers HIGH:!aNULL:!MD5; # 加密算法
 
    location / {
        root /usr/share/nginx/html;
        index index.html index.htm;
    }
}
 
server {
    listen 80;
    server_name ssl.example.com;
    return 301 https://$server_name$request_uri; # 将HTTP请求重定向到HTTPS
}

示例4:动静分离

将静态资源和动态请求分离处理。

server {
    listen 80;
    server_name static.example.com;
 
    location / {
        root /usr/share/nginx/html;
        index index.html index.htm;
    }
 
    location ~* \.(css|js|jpg|jpeg|png|gif|ico|svg|woff|woff2|ttf|otf)$ {
        root /usr/share/nginx/static; # 静态资源目录
        expires 30d; # 设置缓存过期时间
    }
 
    location /api/ {
        proxy_pass http://api.backend.example.com; # 动态请求代理到后端API服务器
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

总结

本文详细介绍了NGINX的配置文件结构,并通过多个示例展示了NGINX的多种配置方法。掌握这些配置技巧,可以帮助您更好地管理和优化Web服务器的性能。

相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
相关文章
|
10月前
|
应用服务中间件 Linux 网络安全
Centos 8.0中Nginx配置文件和https正书添加配置
这是一份Nginx配置文件,包含HTTP与HTTPS服务设置。主要功能如下:1) 将HTTP(80端口)请求重定向至HTTPS(443端口),增强安全性;2) 配置SSL证书,支持TLSv1.1至TLSv1.3协议;3) 使用uWSGI与后端应用通信(如Django);4) 静态文件托管路径设为`/root/code/static/`;5) 定制错误页面(404、50x)。适用于Web应用部署场景。
958 87
|
6月前
|
编解码 应用服务中间件 Linux
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
592 1
|
10月前
|
负载均衡 应用服务中间件 nginx
Nginx配置与命令
Nginx 是一款高性能的 HTTP 和反向代理服务器,其配置文件灵活且功能强大。本文介绍了 Nginx 配置的基础结构和常用指令,包括全局块、Events 块、HTTP 块及 Server 块的配置方法,以及静态资源服务、反向代理、负载均衡、HTTPS 和 URL 重写等功能实现。此外,还提供了常用的 Nginx 命令操作,如启动、停止、重载配置和日志管理等,帮助用户高效管理和优化服务器性能。
986 14
|
6月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
384 18
|
6月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
612 17
|
7月前
|
数据建模 应用服务中间件 PHP
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
本示例演示如何通过Docker挂载同一宿主目录至Nginx与PHP容器,实现PHP项目运行环境配置。需注意PHP容器中监听地址修改为0.0.0.0:9000,并调整Nginx配置中fastcgi_pass指向正确的IP与端口。同时确保Nginx容器中/var/www/html权限正确,以避免访问问题。
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
|
8月前
|
应用服务中间件 网络安全 nginx
配置Nginx以支持Websocket连接的方法。
通过上述配置,Nginx将能够理解WebSocket协议的特殊要求,代理Websocket流量到合适的后端服务器。注意,Websocket并不是HTTP,尽管它最初是通过HTTP请求启动的连接升级,因此保证Nginx了解并能够妥善处理这种升级流程是关键。
1879 10
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
1196 7
|
7月前
|
Ubuntu 应用服务中间件 Linux
在Ubuntu上配置Nginx实现开机自启功能
至此,Nginx应该已经被正确地设置为开机自启。在Ubuntu中利用 `systemd`对服务进行管理是一种高效的方式,为系统管理员提供了强大的服务管理能力,包括但不限于启动、停止、重启服务,以及配置服务的开机自启动。通过这些简洁的命令,即使是对Linux不太熟悉的用户也能轻松地进行配置。
375 0
|
9月前
|
安全 应用服务中间件 网络安全
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
685 0
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡