中间件配置文件-nginx
2021/10/13 7:17:38
本文主要是介绍中间件配置文件-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的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-13用Nginx防范DDoS攻击的那些事儿
- 2024-12-13用Terraform在AWS上搭建简单NGINX服务器指南
- 2024-10-29Nginx发布学习:从入门到实践的简单教程
- 2024-10-28Nginx发布:新手入门教程
- 2024-10-21nginx 怎么设置文件上传最大20M限制-icode9专业技术文章分享
- 2024-10-17关闭 nginx的命令是什么?-icode9专业技术文章分享
- 2024-09-17Nginx实用篇:实现负载均衡、限流与动静分离
- 2024-08-21宝塔nginx新增8022端口方法步骤-icode9专业技术文章分享
- 2024-08-21nginx配置,让ws升级为wss访问的方法步骤-icode9专业技术文章分享
- 2024-08-15nginx ws代理配置方法步骤-icode9专业技术文章分享