1.主要应用场景
- 通过本地文件系统提供静态资源服务,也就是常说的静态资源分离
- 利用其强大性能,缓存,负载均衡为服务端提供反向代理服务
- 提供API服务
2.优点
- 高并发,高性能
- 可扩展性好
- 高可靠性
- 热部署
- BSD许可证
3.Nginx的组成
- Nginx二进制可执行文件(由各模块原码编译出的一个文件)
- Nginx.conf配置文件(控制Nginx的行为)
- access.log(记录每一条http请求信息)
- error.log(记录错误日志,定位问题)
4.Nginx语法介绍
- 配置文件由指令与指令块构成
- 指令块以{}大括号将多条指令组织在一起
- 使用#符号添加注释,提高可读性
- include语句允许组合多个配置文件以提升可维护性
- 使用$符号使用变量
- 部分指令的参数支持正则表达式
5.命令行简介
- nginx -s reload 重新加载配置文件
- nginx -s stop 立刻停止服务
- nginx -s quit 友好的停止服务,也就是等nginx处理完请求后停止
- nignx -s reopen 重新开始记录日志
- nginx -t 检测配置文件语法是否有问题
- nginx -v 打印nginx 版本,编译信息
6.配置文件nginx.conf结构
组成模块 | 说明 |
main | 主要控制 Nginx 子进程所属的用户和用户组、派生子进程数、错误日志位置与级别、 pid 位置、子进程优先级、进程对应 CPU 、进程能够打开的文件描述符数目 等 |
events | 控制 Nginx 处理连接的方式 |
http | Nginx 处理 http 请求的主要配置块,大多数配置都在这里面进行 |
server | Nginx 中主机的配置块,可用于配置多个虚拟主机 |
location | server 中对应目录级别的控制块 ,可以有多个 |
7.配置文件参数详解
#user nobody;
worker_processes 1;#配置 Nginx 的工作进程数, 一般设为 CPU 总核数或者总核数的两倍
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;#配置 Nginx 允许单个进程并发连接的最大请求数
}
http {
include mime.types;#用于引人配置文件
default_type application/octet-stream;#设置默认文件类型
#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;#默认值为 on ,表示开启高效文件传输模式
#tcp_nopush on;
#keepalive_timeout 0;#设置长连接超时时间(单位:秒)
keepalive_timeout 65;
#gzip on;
server {
listen 80;#监听端口,默认监听 80 端口
server_name localhost;#设置主机域名
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;#设置主机站点根目录地址
index index.html index.htm;#指定默认索引文件
}
#error_page 404 #http响应码 /404.html;#自定义错误页面
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
#location ~ /\.ht {
# deny all; #访问权限控制,deny是拒绝,allow是允许
#}
}
}
8.ngxin进程设计思想
由一个主进程和多个工作进程组成,主进程接收容户端请求,转交给工作进程处理,从而很好地利用多核心 CPU 的计算能力。当管理员执行 reload 命令重新加载自己直时,主进程会等待工作进程完成 工作 后再结束工作进程,然后基于新的配直重新创建工作进程,避免了工作过程中被打断的情况 。 由于整个过程中主进程没有停止,因此也不会发生漏掉客户端请求的情况