Appearance
Nginx 反向代理配置详解
简介
Nginx 是高性能的 HTTP 和反向代理服务器,广泛应用于 Web 服务部署。
基本配置
静态网站
nginx
server {
listen 80;
server_name example.com;
root /var/www/html;
index index.html;
location / {
try_files $uri $uri/ =404;
}
}反向代理
nginx
server {
listen 80;
server_name api.example.com;
location / {
proxy_pass http://localhost: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;
}
}HTTPS 配置
Let's Encrypt 证书
nginx
server {
listen 443 ssl http2;
server_name example.com;
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
location / {
proxy_pass http://localhost:3000;
}
}
# HTTP 重定向到 HTTPS
server {
listen 80;
server_name example.com;
return 301 https://$server_name$request_uri;
}负载均衡
nginx
upstream backend {
server backend1.example.com weight=3;
server backend2.example.com;
server backend3.example.com;
}
server {
listen 80;
location / {
proxy_pass http://backend;
}
}性能优化
Gzip 压缩
nginx
gzip on;
gzip_vary on;
gzip_min_length 1024;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml;缓存配置
nginx
location ~* \.(jpg|jpeg|png|gif|css|js)$ {
expires 7d;
add_header Cache-Control "public, immutable";
}最佳实践
- 使用 HTTP/2 提升性能
- 启用 Gzip 压缩减少传输大小
- 合理配置缓存策略
- 使用 HTTPS 保证安全
- 定期更新 SSL 证书
常用命令
bash
# 测试配置
sudo nginx -t
# 重新加载配置
sudo nginx -s reload
# 查看状态
sudo systemctl status nginx
# 查看日志
sudo tail -f /var/log/nginx/access.log
sudo tail -f /var/log/nginx/error.log总结
Nginx 功能强大且性能优异,是 Web 服务部署的首选方案。