中间件配置文件-nginx

文章目录

  • 前言
  • **3.** **解析配置文件:**
    • **3.1** **全局配置:**
    • **3.2 http指令块:**
    • **3.3 server指令块:**
    • **3.4 location指令块:**
  • 总结


前言

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资源,都拒绝。

总结

你可能感兴趣的:(nginx,中间件配置文件,中间件配置文件)