Nginx配置详解

Nginx 是一个高性能的 HTTP 和反向代理 web 服务器,同时也提供了 IMAP/POP3/SMTP 服务,其因丰富的功能集、稳定性、示例配置文件和低系统资源的消耗受到了开发者的欢迎。

本文,我们总结了一些常用的 Nginx 配置代码,希望对大家有所帮助。

监听端口

server {
  # Standard HTTP Protocol 标准HTTP协议
  listen 80;

  # Standard HTTPS Protocol 标准HTTPS协议
  listen 443 ssl;

  # For http2
  listen 443 ssl http2;

  # Listen on 80 using IPv6
  listen [::]:80;

  # Listen only on using IPv6
  listen [::]:80 ipv6only=on;
}

访问日志

server {
  # Relative or full path to log file
  access_log /path/to/file.log;

  # Turn 'on' or 'off'
  access_log on;
}

域名

server {
  # Listen to domains(域名)
  server_name www.domain.com;

  # Listen to multiple domains
  server_name www.domain.com www.domain.com;

  # Listen to all domains
  server_name *.domain.com;

  # Listen to all top-level domains
  server_name domain.*;

  # Listen to unspecified Hostnames (Listens to IP address itself)
  server_name "";

}

静态资产

server {
  listen 80;
  server_name domain.com;

  location / {
           root /z/workspace/builduis/web-b/dist;
  } 
}

重定向

server {
  listen 80;
  server_name www.domain.com;
  return 301 http://domain.com$request_uri;
}
server {
  listen 80;
  server_name www.domain.com;

  location /redirect-url {
     return 301 http://otherdomain.com;
  }
}

反向代理

server {
  listen 80;
  server_name domain.com;

  location / {
     proxy_pass http://192.168.5.110:8010;
  }

}

负载均衡

upstream app-server {
  server 0.0.0.0:8010;
  server 0.0.0.0:8011;
  server 192.168.5.110;
}

server {
  listen 80;
  server_name domain.com;

  location / {
     proxy_pass http://app-server;
  }
}

SSL 协议

server {
  listen 443 ssl;
  server_name domain.com;

  ssl on;

  ssl_certificate /path/to/cert.pem;
  ssl_certificate_key /path/to/privatekey.pem;

  ssl_stapling on;
  ssl_stapling_verify on;
  ssl_trusted_certificate /path/to/fullchain.pem;

  ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  ssl_session_timeout 1h;
  ssl_session_cache shared:SSL:50m;
  add_header Strict-Transport-Security max-age=15768000;
}

# Permanent Redirect for HTTP to HTTPS
server {
  listen 80;
  server_name domain.com;
  return 301 https://$host$request_uri;
}

前后端配置示例

server {
    listen       80;
    server_name 192.168.5.110;  #项目域名
    root /z/workspace/builduis/web-a/dist;  #vue项目打包后的dist
    location / {
        try_files $uri $uri/ /index.html; #解决页面刷新404问题                    
        index index.html;
    }

    location /prod-api/ { #后端服务
         proxy_pass http://192.168.5.110:8080/;
         proxy_set_header   X-Forwarded-Proto $scheme;
         proxy_set_header   X-Real-IP         $remote_addr;
         proxy_connect_timeout 600;
         proxy_read_timeout 600;
         proxy_send_timeout 600;
         proxy_buffer_size 64k;
         proxy_buffers   4 32k;
         proxy_busy_buffers_size 64k;
         proxy_temp_file_write_size 64k;
    }

    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
}

nginx部署多个前端vue项目,有3种方式,具体可以参考:

nginx部署多个前端vue项目

Nginx 是一个高性能的开源 Web 服务器和反向代理服务器。它的配置文件是一个重要的部分,影响着服务器的行为和性能。下面是对 Nginx 配置文件的详细解释: 1. 配置文件位置: Nginx配置文件通常位于 /etc/nginx/nginx.conf。此外,可以通过 include 语句包含其他配置文件,使配置更加模块化。 2. 基本结构: Nginx配置文件由多个指令和块组成。指令是配置文件的最小单位,而块是由一对花括号括起来的指令集合。配置文件从上到下按顺序解析,遇到块会进一步解析块内的指令。 3. 主要指令: - worker_processes:指定 Nginx 创建的进程数。通常设置为 CPU 核心数的倍数。 - events:配置 Nginx 处理连接和请求的事件模型。 - http:定义 HTTP 服务器的全局配置。 - server:定义一个虚拟主机(或称为 server block),可以包含多个 location 块。 - location:根据请求的 URI 匹配规则,定义不同的请求处理方式。 4. 常用配置选项: - listen:指定监听的 IP 地址和端口。 - server_name:指定虚拟主机的域名。 - root:指定网站根目录。 - index:指定默认的索引文件。 - location:根据匹配规则指定不同的处理方式,如代理、重定向、静态文件处理等。 5. 变量和指令: Nginx 支持一些内置变量和指令,用于实现动态的配置和请求处理。常见的变量包括 $uri、$args 和 $http_user_agent,常见的指令包括 if、rewrite 和 return。 6. 配置文件的重载: 在修改配置文件后,可以通过发送信号给 Nginx 进程来重新加载配置,而无需停止服务器。常用的信号有 HUP(重新加载配置)和 TERM(停止服务器)。 这些是 Nginx 配置文件的一些基本概念和常用指令。具体的配置方式和使用方法可以根据实际需求进行深入学习和探索。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值