一、404 Not Found 错误
问题描述
访问某个 URL 时返回 404 错误,表示请求的资源未找到。
解决方案
- 检查 URL 是否正确
确保输入的 URL 与实际资源路径匹配。 - 确认配置中的 root 或 alias 是否正确
示例配置:
location / {
root /var/www/html; # 确保此路径下有 index.html
index index.html;
}
- 检查文件是否存在
使用命令确认文件是否在指定目录中:
ls /var/www/html/index.html
- 检查 location 块的规则
确保其他 location 配置未导致覆盖。
二、502 Bad Gateway 错误
问题描述
Nginx 作为反向代理时,后端服务不可用或响应错误,导致 502 错误。
解决方案
- 确认后端服务是否运行正常
systemctl status myapp
- 验证 proxy_pass 配置
location /api/ {
proxy_pass http://127.0.0.1:8080; # 确保后端服务运行在该地址
}
- 查看日志
检查 Nginx 日志(/var/log/nginx/error.log)和后端服务日志。 - 检查防火墙
确保防火墙未阻止 Nginx 与后端的通信。
三、403 Forbidden 错误
问题描述
访问资源时,返回 403 错误,表示服务器拒绝访问。
解决方案
- 检查文件权限
确保 Nginx 用户(如 www-data 或 nginx)有读取权限:
chown -R www-data:www-data /var/www/html
chmod -R 755 /var/www/html
- 检查 Nginx 配置的访问控制指令
location /private/ {
deny all; # 检查是否有不必要的拒绝配置
}
- 排查 SELinux 设置
暂时禁用 SELinux 以确认问题:
setenforce 0
四、Nginx 启动失败
问题描述
修改配置后,Nginx 启动失败或无法加载配置。
解决方案
- 验证配置语法
nginx -t
- 查看错误日志
查阅 /var/log/nginx/error.log 以定位问题。 - 检查端口占用
netstat -luntp | grep :80
五、连接超时
问题描述
访问网站时出现连接超时。
解决方案
- 检查网络连接
ping example.com
- 优化超时设置
proxy_read_timeout 60s;
proxy_connect_timeout 60s;
- 优化后端服务性能
确保后端服务能够及时响应请求。
六、SSL/TLS 相关错误
问题描述
配置 HTTPS 时遇到证书错误或握手失败。
解决方案
- 验证证书和私钥路径
ssl_certificate /etc/ssl/certs/example.crt;
ssl_certificate_key /etc/ssl/private/example.key;
- 检查证书有效性
openssl x509 -in /etc/ssl/certs/example.crt -text -noout
- 配置安全协议
ssl_protocols TLSv1.2 TLSv1.3;
七、配置更改无效
问题描述
修改配置后发现更改未生效。
解决方案
- 重新加载配置
nginx -s reload
- 检查修改文件路径
确保在正确的配置文件中进行修改,通常为 /etc/nginx/nginx.conf 或 /etc/nginx/conf.d/ 下的文件。 - 查看错误日志确认是否有相关错误提示。
八、资源占用过高
问题描述
Nginx 的 CPU 或内存占用过高,影响性能。
解决方案
- 优化配置
调整 worker_processes 和 worker_connections的值以匹配硬件性能:
worker_processes auto;
events {
worker_connections 1024;
}
- 分散流量
使用负载均衡方案分散流量,避免单实例过载。
未完待续