nginx
nginx(web server , web reverse proxy):
http协议:80/tcp, HyperText Iransfer Procotol
html:HypreText Mark Language(超文本标记语言)
文本:HTTP/1.0 MIME
MIME:Multipurpose Internet Mail Extension
major/minor
text/plain
image/jpeg
URL:scheme://server[:port]/path/to/source
http事务:request <--> response
request
response
协议格式:文本、二进制
method
GET、HEAD、POST、PUT、DELETE、TRACE、OPTIONS
status
1xx:信息类
2xx:成功类
3xx:重定向类
4xx:客户端错误类
5xx:服务器端错误
HEADER
通用首部
请求首部
响应首部
实体首部
扩展首部
web页面:多个资源
入口:资源引用:
认证:
基于IP认证:
基于用户访问:
basic
digest
资源映射:
Alias
DocumentRoot
httpd:MPM(多路处理模块)
prefork ,worker ,event(第一种是进程模型,后两种是线程模型)
prefork:主进程,生成多个子进程,每个子进程处理一个进程
worker:主进程,生成多个子进程,每个子进程生成多个线程,每个线程响应一个请求
event:主进程,生成多个子进程,每个子进程响应多个请求
I/O类型
同步和异步:
关注的是消息通知机制
同步:调用发出之后不会立即返回,但一返回,则返回的即是最终结果
异步:调用发出之后,被调用方立即返回消息,但返回的并非最终结果:被调用者通过状态,通知机制等来通知调用者,或通过回调函数来处理结果:
阻塞和非阻塞
关注的是调用者等待被调用者返回调用结果时的状态
阻塞:调用结果返回之前,调用者会被挂起,调用者只有在得到返回结果之后才能继续
非阻塞:调用者在结果返回之前,不会被挂起,即调用不会阻塞调用者
I/O模型:
blocking IO 阻塞式IO
nonblocking IO 非阻塞式IO
IO multiplexing 复用性IO
select():最多不能超1024个并发,poll():profork、worker
singnal driven IO 事件驱动型IO:event
增加了通知机制
水平触发:多次通知
边缘通知:只通知一次
asynchronous IO: 异步型IO
eopll
例如:一次read操作
(1)等待数据准备好,从磁盘到内核内存
(2)从内核内存复制到进程内存
nginx
Nginx:engine X
Tngine
Registry
libevent:高性能的网络库
epoll()
Nginx特性
模块化设计,较好的扩展性
高可靠
master --> worker
低内存消耗
10000个keep-alive模式下的connection,仅需要2.5MB内存
支持热部署
不停机而更新配置文件,日志文件滚动,升级程序版本
支持事件驱动、AIO、mmap
基本功能
静态资源的web服务器,能缓存打开的文件描述符
http、smtp、pop3 协议的反向代理服务器
支持缓存加速,负载均衡机制
支持FastCGI(fpm,LNMP),uWSGI(python)等
模块化(非DSO机制)、过滤器zip,SSI及图像的大小调整
支持SSL
扩展功能
基于名称和IP的虚拟主机
支持keeplive
支持平滑升级
定制访问日志,支持使用日志缓冲区提供日志存储性能
支持url rewrite
支持路径别名
支持基于IP和用户的访问控制
支持速率限制,支持并发数限制
Nginx的基本架构
一个master进程,生成一个或多个worker进程
事件驱动,epoll(边缘触发),kqueue:BSD系统,/dev/poll
复用器:select,poll,rt signal
支持sendfile,sendfile64
支持AIO
支持mmap
nginx的工作模式:非阻塞,时间驱动,有一个master进程生成多个worker线程,每个worker响应N个请求
worker * n
模块类型
核心模块
Standard HTTP modules
Optional HTTP modules
Mail modules
3rd party modules
安装方法:
源码:编译安装
编译安装: ./configure --help(查看帮助)
配置文件:
main配置段:全局配置段
event:定义event模型工作特性
http{}:定义http协议的相关配置
配置指令:要以分号结尾,语法格式:
directive value1[value2 ...]
支持使用变量
内置变量
模块会提供几建变量定义
自定义变量
set var_name value
主配置段指令
用于调试、定位问题
正常运行必备的配置
优化性能的配置
事件相关的配置
nginx:非阻塞、事件驱动、异步
主配置段的指令
正常运行的必备配置
1、user USERNAME[GROUPNAME]
指定运行worker进程的用户和组
2、pid /path/to/pid_file
指定nginx守护进程的pid文件
3、worker_rlimit_nofile # ;
指定所有worker进程所能够打开的最大文件句柄数
性能优化的相关配置
1、worker_processes #
所能打开的worker进程的个数:通常应该略少于cpu物理核心数
2、worker_cpu_affinity cpumask...
优点:提升缓存的命中率
context switch (进程切换):会产生cpu的不必要的消耗
cpumask:
0000 0000
0000 0001
0000 0010
0000 0100
0000 1000
worker_cpu_affinity 00000001 00000010 00000100 (绑定前三颗cpu)
3、time_resolution
计时器解析度:降低此值,可减少gettimeofday()系统调用的次数
4、work_priority number;
指明worker进程的nice值,nice值越小,优先值越高
-20 19
100 139
事件相关的配置
1、accept_mutex {off|on};
master调度用户请求至各worker进程时使用的负载均衡锁:on表示能让多个worker轮流的,序列化的去响应新请求;
2、lock_file file:
accept_mutex用到的锁文件路径
3、use [epoll|rtsig|select|poll]
指明使用的事件模型:建议让nginx自行选择
4、worker_connection #;
设定单个worker进程所能够处理的最大并发连接数
worker_connection (51200)* worker_processes
用于调试,定位问题,(解码时,要加上这个包 --with-debug)
1、daemon {on|off}
是否已守护进程方式,来运行nginx:调试时应设置为off
2、master_process {on|off}
是否以master/worker模型来运行nginx;调试时可以调试为off
3、error_log 位置 级别;
若要使用debug级别,需要在编译nginx时使用了 --with-debug选项
nginx作为web服务器时使用的配置:
http{}:由ngx_http_core_module模块所引入:
配置框架:
http{
upstream{
..
}
server{
location URL{
...
}#类似于httpd中的
location URL {
if...{
}
}
...
}#每个server类似于httpd中的一个
}
注意:与http相关的指令仅能够放置于http、server、location、upstream、if上下文,但有些指令仅用于这五种上下文中的某些中:
配置指令;
1、server{}
定义一个虚拟主机的
2、listen
指定监听的端口和地址
3、server_name NAME [...]
后可跟多个主机;名称还可以使用正则表达式(~)或通配符;
(1)先做精确匹配检查;
(2)左侧通配符匹配检查
(3)右侧通配符匹配检查
(4)正则表达式匹配检查
(5)default_server
4、root path:
设置资源路径映射;用于指明请求的URL所对应的资源所在的文件系统上的起始路径
5、location
功能:允许根据请求的URL来匹配定义的各location。匹配到时,此请求将被相应的location配置块中的配置所处理,例如做访问控制等功能
= :精确匹配检查
~:正则表达式模式匹配检查,区分字符大小写
~*:正则表达式模块匹配检查,不区分字符大小写
^~: URL的前半部分匹配,不支持正则表达式
匹配优先级:= > ^~ > ~ > ~* > 不带任何符号的
6、alias path;
用于location配置段,定义路径别名
注意:root表示指明路径为对应的location"/"URL; alias 表示路径映射,即location指令后定义的URL是相对于alias所知名的路径而言
7、 index file;
默认主页面:
index index.php index.html;
8、error_page code [...] [=code] URL | @name
根据http响应状态码来指明待用的错误页面:
error_page 404 [= 200]/404_customed.html
[=code]: 以指定的响应码进行响应,而不是默认的原来的响应码:默认表示以新资源的响应码为其响应码:
9、基于IP的访问控制机制
allow IP/network
deny IP/network
10、基于用户的访问控制
basic,digest
auth_basic "" ;
auth_basic_user_file "/PATH/TO/PASSWORD_FILE
账号密码文件建议使用htpasswd来创建
11、https服务
生成私钥,生成证书签署请求,并获得证书
server {
listen 443 ssl;
server_name www.baidu.com
ssl_certificate /etc/nginx/ssl/nginx.crt
ssl_cretificate_key /etc/nginx/ssl/nginx.crt
ssl_session_cache shsred:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers HIGH:!aNULL:!MDS
ssl_prefer_server_ciphers on;
location / {
root /data/web
index index.html index.htm
}
}
12、stub_ststus {on|off}
仅能用于location上下文
location /ststus {
stub_status on;
}
13、rewrite regex replacement flag;
例如:
rewrite ^/images/(.*\.jpg)$ /imgs/$ break;
flag:
last:一旦此rewrite规则重写完成后,就不再被后面其他的rewrite规则进行处理,而是由User Agent重新对重写后的URL再一次发起请求,并从头开始执行类似的过程
break;一旦此rewrite规则重写完成后,由User Agent对新的URL重写发起请求,且不再会被当前location内的任何rewrite规则所检查
redirect:以302响应码(临时重定向)返回新的URL
permanent:以301响应码(永久重定向)返回新的URL
14、if
语法:if(condition){...}
应用语法: server , location
condtion:
(1)变量名:
变量值为空串,或者以“0”开始,则为false,其他均为true
(2)以变量为操作数构成的比较表达式
可使用=,!= 类似的比较操作符进行测试
(3)正则表达式的模式匹配操作
~:区分大小写
~*:不区分大小写
!~和!~*:对上面两种测试取反
(4)测试文件存在性:-f,!-f
(5)测试指定路径为目录的可能性:-d ,!-d
(6)测试文件存在性:-e,!-e
(7)检查文件是否有执行权限:-x,!-x
15、防盗链
location ~*\.(jpg|gif|jpeg|png)$ {
valid_referer none blocked www.baidu.com;
if ($invialid_referer) {
rewrite ^/ http://www.baidu.com/403.html
}
}
16、定制访问日志格式
log_format
网络连接相关的配置
1、keeplive_timeout #
长连接的超时时长,默认75秒
2、keeplive_requests #
在一个长连接上所能够允许请求的最大资源数
3、keeplive_disable [msie6|safari|none]
为指定类型的User Agent禁用长连接
4、tcp_nodelay on|off
是否对长连接使用TCP_NODELAY选项;(如想提升用户体验,使用on)
5、client_header_timeout #;
读取http请求报文首部的超时时长
6、client_body_timeout #;
读取http请求报文body部分的超时时长
7、send_timeout #;
发送响应报文的超时时长
fastcgi的相关配置
lnmp:php要启用fpm模型