Ngnix学习笔记

一.Ngnix介绍
1.概念
一个强大的Web服务器软件.
2.功能
1)处理高并发的http请求.
2)作为反向代理服务器来进行负载均衡.
3)数据压缩和解压缩处理
3.优势
高性能,轻量级,内存消耗少,强大的负载均衡能力等.
二.Master/Worker进程
Ngnix启动后,在系统中以daemon的方式在后台运行,包含一个Master进程和n(n>=1)个Worker进程.
Master进程:接受来自外界的信号,给Worker进程发送信号,监控Worker进程的工作状态.
Worker进程:外部请求的真正处理者.一个Worker进程只能有一个主线程.
高并发的处理方式:异步非阻塞(即单线程,非阻塞,异步IO的工作模型),相比apache,ngnix省去了线程上下文切换所带来的资源开销.
三.如何进行http请求处理
1.Master进行fork每个Worker进程.
2.Worker进程调用accept接受连接(此步比较复杂).
3.开始读取请求,解析请求,处理请求,断开连接.
四.如何进行负载均衡
Ngnix支持的通信协议:http,https.
ngnix以反向代理的方式进行负载均衡.
反向代理方式:指以代理服务器来接受请求,然后代理服务器将请求转发给内网服务器,获取内网服务器结果后返回给请求连接的客户端,此时代理服务器对外就表现为一个服务器.
正向代理方式:指一个位于客户端和目标服务器之间的服务器,客户端向代理服务器发送一个请求并指定目标服务器,然后代理向目标服务器转交请求并获得内容返回客户端.(插播)
五.压缩解压缩处理
压缩:数据发送客户端之前,ngnix会对响应做压缩,如果后端服务器已经进行了压缩处理,则ngnix就不再进行压缩.
解压缩:解压缩指令在预编译的开源ngnix中没有,属于一个单独的模块,需要编译到ngnix中去.
六.负载均衡技术(补充)
硬件层面:F5负载均衡器
网络层面:LVS(Linux Virtual Server)
应用层面:Nignix,Haproxy等.
posted @ 2017-07-19 20:01  疯狂的蜗牛仔  阅读(548)  评论(0编辑  收藏  举报