nginx.conf核心配置文件

1.设置worker进程的用户,linux中的用户,涉及到nginx操作目录或文件的一些权限,默认为nobody
nginx.conf核心配置文件

	user root;

2.worker进程数,设置数与cpu相同或比cpu少一个

	worker_processes 1;

3.nginx日志级别 | debug | info| notice | warn | error | crit | alert | emerg |,错误级别从左到右越来越大

	error_log logs/error.log notice;
	error_log logs/error.log info;

4.设置nginx进程pid

	pid logs/nginx.pid

5.设置工作模式

	events{
		#默认使用epoll
		use epoll;
		#每个worker允许连接的客户端最大数
		worker_connections 1024;
	}

6.include引入外部配置,提高可读性,可以避免配置文件过大

	include		mime.types;

7.设置日志输出格式,main为定义的格式名称,access_log可以直接使用这个变量

log_format	main	'$remote_addr - $remote_user [$time_local] "$request" '
					'$status $body_bytes_sent "$http_referer"'
					'"$http_user_agent" "$http_x_forwarded_for"';

access_log log/access.log main;					

参数解析

参数名 参数意义
$remote_addr 客户端ip
$remote_user 远程客户端用户名,一般为‘-’
$time_local 时间和时区
$request 请求的url以及method
$status 响应状态码
$body_bytes_sent 响应客户端内容字节数
$http_referer 记录用户从哪个连接跳过来的
$http_user_agent 用户所使用的代理
$http_x_forwarded_for 通过代理服务器来记录客户端ip

8.sendfile使用高效文件传输,提高传输性能。启用后才能使用tcp_nopush,tcp_nopush是指当数据表积累一定大小后才发送,提高了效率

	sendfile		on;
	tcp_nopush		on;

9.keepalive_timeout 设置客户端与服务器端请求的超时时间,保证客户端多次请求的时候不会重复建立新的连接,节约资源损耗。

	keepalive_timeout 65;
	# keepalive_timeout 0;

10. gzip启用压缩,html/js/css压缩后传输会更快

	gzip	on;

11.server可以在http指令块中设置多个虚拟主机

  • listen 监听端口
  • server_name localhost ip或域名
  • location 请求路由映射,匹配拦截
  • root 请求位置
  • index 首页设置
werver{
        location / {
            root   myhtml;
            index  myindex.html index.htm;
        }

}
上一篇:#c语言输入学生成绩输出其成绩等级#


下一篇:LeetCode-227. 基本计算器 II