3、nginx排错
nginx排错
2021.1.1-TS:nginx 报错文件描述符不够,返回了 500 错误码(仅收藏)
报错现象
网站第一次事故:网站上线 10 分钟就挂了,原因是我没有调大 nginx 的 worker 进程的文件描述符,导致有大量客户端访问的时候,nginx 报错文件描述符不够,返回了 500 错误码。
来自:
小林coding
为什么会有 500 错误?
收到大家反馈的错误后,我马上就去服务器查看 nginx 的 error 日志了,发现频繁报错了这个错误:“Too many open files”。
很快我就知道是文件描述符受限而导致 nginx 频繁报这个错误,每一个 TCP 连接都会占用一个文件描述符,当时发文不到 10 分钟,文章阅读就已经 1000 多了,瞬间一下子 1000 多个请求过来,就导致文件描述符被占满了,从而 nginx 就回 500 错误。
解决办法
所以,要解决这个问题,就要调大文件描述符的显示。
首先,先来看看系统的最大描述符数:
这个是默认值,有 18 万个,那肯定不是这里受限。
然后,通过 ulimit -n 查看每个用户的最大描述符数:
这个也是默认值,也有 6.5 万个,说明也不是这里受限。
然后,通过 /proc//limits 这个文件查看 nginx 工作进程的最大描述符数:
可以看到,最大值才 1024 个!猜测 nginx 工作进程的最大描述符数太小而导致 nginx 报 Too many open files 的错误。
要怎么调大 nginx 的工作进程的最大描述符数呢?
很简单,只需要在 nginx.conf 配置调大 worker_rlimit_nofile 的值,这个参数单跟每个工作进程可以建立的最大连接数量息息相关,我这里调大到了 65535。
然后重新 reload nginx 的配置,再查看 /proc//limits:
可以看到,nginx 的工作进程最大描述符已经设置为 65535。
调大 nginx 工作进程最大描述符后,nginx 的 error 日志就没有在报错了,至此 500 错误的问题就解决了。
2023.12.31-TS-nginx提供的http web服务浏览器界面显示中文为乱码(已解决)
- 故障环境
centos7.9
nginx version: nginx/1.20.1
故障现象
解决办法
nginx提供的http web服务浏览器界面显示中文为乱码?
如果 Nginx 提供的 HTTP Web 服务在浏览器中显示中文为乱码,可能是由于字符编码设置不正确导致的问题。以下是一些建议的解决方法:
-
设置字符编码:
-
在 Nginx 配置文件中,确保设置了正确的字符编码。你可以在配置文件的
http
块中添加如下设置:charset utf-8;
这会告诉浏览器使用 UTF-8 字符编码来解析页面内容。
-
- 测试过程
vim /etc/nginx/nginx.conf
……
charset utf-8;
重启Nginx。
测试效果
(问题已解决)
2024.8.4-TS-server_name字段错误配置(已解决)
故障现象
nginx: [warn] server name "https://$host$request_uri" has suspicious symbols in /etc/nginx/conf.d/blog.conf:47 这个是为啥?
这个警告 nginx: [warn] server name "https://$host$request_uri" has suspicious symbols in /etc/nginx/conf.d/blog.conf:47
表示在你的 Nginx 配置文件中的 server_name
指令包含了不适合的位置变量或字符。具体来说,server_name
指令只应该包含域名或IP地址,而不 能包含协议 (https://
) 或请求 URI ($request_uri
等)。
可能的错误配置
你可能在 server_name
指令中错误地使用了变量或协议。例如:
server {
listen 80;
server_name https://$host$request_uri;
# 其他配置...
}
这是错误的配 置,因为 server_name
只应包含域名。
解决方法
确保在 server_name
指令中仅包含适当的域名或 IP 地址。例如,假设你希望匹配主域名和子域名,你可以这样配置:
server {
listen 80;
server_name onedayxyy.cn *.onedayxyy.cn;
# 其他配置...
}
如果你需要将所有 HTTP 请求重定向到 HTTPS,你可以使用 return
指令或 rewrite
指令来实现。例如:
server {
listen 80;
server_name onedayxyy.cn *.onedayxyy.cn;
location / {
return 301 https://$host$request_uri;
}
}
或者:
server {
listen 80;
server_name onedayxyy.cn *.onedayxyy.cn;
location / {
rewrite ^ https://$host$request_uri? permanent;
}
}