文章目录
前言
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资源,都拒绝。
总结