ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

中间件配置文件-nginx

2021-10-12 10:32:02  阅读:195  来源: 互联网

标签:log 配置文件 中间件 nginx location 设置 error fastcgi


文章目录


前言

3. 解析配置文件:

3.1 全局配置:

user nobody; 
worker_processes 1; 
#error_log logs/error.log; 
#error_log logs/error.log notice; 
#error_log logs/error.log info; 
#pid logs/nginx.pid; 

events { 
	use epoll; 
	worker_connections 1024; 
}
user :指定nginx的工作进程的用户及用户组,默认是nobody用户。

worker_processes :指定工作进程的个数,默认是1个。具体可以根据服 务器cpu数量进行设置, 
	比如cpu有4个,可以设置为4。如果不知道cpu的数 量,可以设置为auto。 	nginx会自动判断服务器的cpu个数,并设置相应的 进程数。 

error_log :设置nginx的错误日志路径,并设置相应的输出级别。 
	如果编译时没有指定编译调试模块,那么 info就是最详细的 输出模式了。 		如果有编译debug模块,那么debug时最为详细的输出模式。 这里设置为默认就好了。 
	
pid :指定nginx进程pid的文件路径。 

events :这个指令块用来设置工作进程的工作模式以及每个进程的连接上限。 

use :用来指定nginx的工作模式,通常选择epoll,除了epoll,还有 select,poll。

worker_connections :定义每个工作进程的最大连接数,默认是 1024。 

ps:进程的最大连接数受Linux系统进程的最大打开文件数限制。

修改文件描述符方式: 
临时生效: ulimit -n 65535

在压测的时候,如果遇到报错 apr_socket_recv: Connection reset by peer (104): 
解决办法: 
# 临时解决: 
加一个-r参数,避免因为套接字错误退出,但是影响测试结果。 

# 根本解决: 
# vim /etc/sysctl.conf 
net.ipv4.tcp_syncookies = 0 

然后执行:sysctl -p

3.2 http指令块:

http {
	include mime.types; 
	default_type application/octet-stream; 
	charset utf-8; 
	#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 logs/access.log main; 
	Sendfile on; 
	tcp_nopush on; 
	tcp_nodelay on; 
	#keepalive_timeout 0; 
	keepalive_timeout 65; 
	keepalive_requests 100; 
	#gzip on; 
	server {
		... 
		location { 
			root html; 
			... 
		} 
	} 
}
include mime.types; :定义数据类型 
	如果用户请求lutixia.png,服务器上有lutixia.png这个文件,后缀 名是png; 
	根据mime.types,这个文件的数据类型应该是image/png; 
	将Content-Type的值设置为image/png,然后发送给客户端 
	
default_type :设定默认类型为二进制流,也就是当文件类型未定 义时使用这种方式, 
	例如在没有配置PHP环境时,Nginx是不予解析的, 
	此时,用浏览器访问PHP文件就会变成下载。 

charset utf-8; :解决中文字体乱码 
log_format :定义日志文件格式,并默认取名为main,可以自定 义该名字。 
	也可以通过添加,删除变量来自定义日志文件的格 式。
	
access_log :定义访问日志的存放路径,并且通过引用 

log_format所定义的main名称设置其输出格式。 

sendfile on :用于开启高效文件传输模式。直接将数据包封装在 内核缓冲区,然后返给客户,将tcp_nopush和tcp_nodelay两个指令设置为 on用于防止网络阻塞; 

keepalive_timeout 65 :设置客户端连接保持活动的超时时间。在超 过这个时间之后,服务器会关闭该连接。 
keepalive_requests 100 :设置nginx在保持连接状态最多能处理的请 求数,到达请求数,即使还在保持连接状态时间内,也需要重新连接。

提示:可以用netstat -ntlpa |grep 80 查看链接状态 

gzip on :开启压缩功能,减少文 件传输大小,节省带宽。 
gzip_min_length 1k; :最小文件压缩,1k起 压。
gzip_types text/plain text/xml; :压缩文件类型
gzip_comp_level 3; :压缩级别,默认是1。

3.3 server指令块:

server {
	listen 80; 
	server_name localhost; 
	#charset koi8-r; 
	#access_log logs/host.access.log main; 
	index index.html index.htm; 
	location / { 
		root html; 
		... 
	}
	#error_page 404 /404.html; 
	error_page 500 502 503 504 /50x.html; 
	location = /50x.html { 
		root html; 
	}
	#location ~ \.php$ { 
		... 
	#}
	#location ~ /\.ht { 
		# deny all; 
	#} 
}
server :用来定义虚拟主机。 
listen :设置监听端口,默认为80端口 
server_name :域名,多个域名通过逗号或者空格隔开 
Charset :设置网页的默认编码格式 
access_log :指定该虚拟主机的独立访问日志,会覆盖前面的全 局配置。 
index :设置默认的索引文件 
location :定义请求匹配规则。 
error_page :定义访问错误返回的页面,凡是状态码是500 502 503 504 都会返回这个页面。

3.4 location指令块:

#location ~ \.php$ { 
	# root html; 
	# fastcgi_pass 127.0.0.1:9000; 
	# fastcgi_index index.php; 
	# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; 
	# include fastcgi_params; 
	#}
	
	# deny access to .htaccess files, if Apache's document root 
	# concurs with nginx's one 
	#
	#location ~ /\.ht { 
	# deny all; 
	#}
location ~ \.php$ :凡是以php结尾文件,都会匹配到这条规则。 

root :php文件存放的目录 

fastcgi_pass :指定php-fpm进程管理的ip端口或者unix套 接字

fastcgi_index :指定php脚本目录下的索引文件 

fastcgi_param :指定传递给FastCGI服务器的参数 

location ~ /\.ht :凡是请求类似.ht资源,都拒绝。

总结

标签:log,配置文件,中间件,nginx,location,设置,error,fastcgi
来源: https://blog.csdn.net/qq_43058317/article/details/120718437

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有