Nginx使用(三)

nginx

# nginx常用命令

cd /usr/local/nginx/sbin/
./nginx				#启动
./nginx -c /usr/local/nginx/conf/nginx.conf #指定配置文件启动
./nginx -v			#查看版本
./nginx -t			#测试conf文件语法是否正确
./nginx -s stop		#停止服务
./nginx -s quit		#优雅的关闭服务
./nginx -s reload	#重启服务

#查询nginx进程
ps aux|grep nginx

1
2
3
4
5
6
7
8
9
10
11
12

# 静态代理

再nginx.conf配置文件的 server代码块中添加配置

server {
    listen 80;
    
    #所有/images/ 开头的请求,转发到本地指定目录
    location  /images/ {
        alias /home/upload/;
    }
}
1
2
3
4
5
6
7
8

# 反向代理

# 路径拆解代理

server {
    listen 80;

    location /jeecgboot/ {
        proxy_pass http://localhost:9999/;
        # 保留原始请求的 Host头
        proxy_set_header Host $http_host;
        # 向后端传递客户端的真实 IP
        proxy_set_header X-Real-IP $remote_addr;
        # 追加客户端 IP 到代理链(用于追踪原始请求来源)
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
         # 自定义头传递客户端 IP
        proxy_set_header REMOTE-HOST $remote_addr;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

# 集群代理

http {
    
    upstream backend {
        server 10.0.0.1:8080;
        server 10.0.0.2:8080;
    }

    server {
        listen 80;
        location /api/ {
            # 固定代理到 upstream
            proxy_pass http://backend;  
            # 保留原始请求的 Host头
            proxy_set_header Host $http_host;
            # 向后端传递客户端的真实 IP
            proxy_set_header X-Real-IP $remote_addr;
            # 追加客户端 IP 到代理链(用于追踪原始请求来源)
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
             # 自定义头传递客户端 IP
            proxy_set_header REMOTE-HOST $remote_addr;
        }
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

# 代理不同环境

使用 map 创建变量映射,简化逻辑判断。

http { map (输入变量) (输出变量) { 匹配模式1 输出值1; 匹配模式2 输出值2; default 默认值; } }

# 通过cookie代理

根据 Cookie 中的 env 字段路由

# 1.指定单机服务器
http {
    # 设置变量映射,通过cookie中env变量匹配
    map $cookie_env $backend_server {
        default      "http://prod-server:80";
        "dev"        "http://dev-server:80";
    }

    server {
        listen 80;
        location / {
            # 动态代理到 upstream
            proxy_pass $backend_server;
            proxy_set_header Host $host;
        }
    }
}



# 2.指定集群服务器地址
http {
    upstream prod {
        server 10.0.0.1:80;
    }

    upstream dev {
        server 10.0.0.2:80;
    }

    # 设置变量映射,通过cookie中env变量匹配
    map $cookie_env $backend_server {
        default     prod;
        "dev"       dev;
    }
    
    server {
        listen 80;
        location / {
            # 动态代理到 upstream
            proxy_pass $backend_server;
            proxy_set_header Host $host;
        }
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45

# 通过请求路径匹配

  • 请求 /v1/user → 被代理到 v1-server
  • 请求 /v2/user → 被代理到 v2-server
  • 其他路径 → 被代理到 prod-server
http {
    # 定义版本路由映射
    map $request_uri $target_server {
        default             http://prod-server:80;
        ~^/v1/              http://v1-server:80;
        ~^/v2/              http://v2-server:80;
    }

    server {
        listen 80;
        location / {
            proxy_pass $target_server;  # 动态代理目标
            proxy_set_header Host $host;
        }
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

# 开启HTTPS

  1. 创建SSL证书

    # 生成私钥
    openssl genrsa -out /etc/ssl/private/nginx-50096.key 2048
    
    # 生成证书签名请求(CSR)
    openssl req -new -key /etc/ssl/private/nginx-50096.key \
      -out /etc/ssl/certs/nginx-50096.csr \
      -subj "/CN=your-domain.com"
      
    # 生成自签名证书(有效期365天)
    openssl x509 -req -days 365 \
      -in /etc/ssl/certs/nginx-50096.csr \
      -signkey /etc/ssl/private/nginx-50096.key \
      -out /etc/ssl/certs/nginx-50096.crt
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
  2. 配置nginx.conf

    server {
        listen 50096 ssl;  # 重点:指定端口和ssl
        server_name your-domain.com;  # 改为你的域名或IP
    
        # SSL证书配置
        ssl_certificate /etc/ssl/certs/nginx-50096.crt;
        ssl_certificate_key /etc/ssl/private/nginx-50096.key;
    
        # SSL优化参数
        ssl_protocols TLSv1.2 TLSv1.3;
        ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256;
        ssl_prefer_server_ciphers on;
        ssl_session_cache shared:SSL:10m;
        ssl_session_timeout 10m;
    
        # 安全响应头
        add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
        add_header X-Content-Type-Options nosniff;
        add_header X-Frame-Options DENY;
    
        # 应用配置
        location / {
            root /var/www/html;
            index index.html;
            try_files $uri $uri/ =404;
        }
    
        # 错误页面
        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
            root /usr/share/nginx/html;
        }
        
        
               # 代理API请求
            location /api/ {
                    # 注意:这里将请求转发到服务器B的HTTP服务
                    proxy_pass http://10.110.45.17:9999/;   # 注意末尾的斜杠,确保去除/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;
                    proxy_set_header X-Forwarded-Proto $scheme;
    
    				# 隐藏后端返回的CORS头
    			    proxy_hide_header 'Access-Control-Allow-Origin';
                    # CORS响应头 - 放在代理location中
                    add_header 'Access-Control-Allow-Origin' $http_origin always;
                    add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE' always;
                    add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization' always;
                    add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range' always;
                    add_header 'Access-Control-Allow-Credentials' 'true' always;  # 添加此项支持身份验证
            }
    
    
    }
    
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
更新时间: 3 个月前