Nginx基础
为什么要用Nginx?
-跨平台、配置简单
-非阻塞、高并发连接:处理2-3万并发连接数,官方监测能支持5万并发
-内存消耗小:开启10个nginx才占150M内存,Nginx采取了分阶段资源分配技术
-nginx处理静态文件好,耗费内存少
-内置的健康检查功能:如果有一个服务器宕机,会做一个健康检查,再发送的请求就不会发送到宕机的服务器了。重新将请求提交到其他的节点上。
-节省宽带:支持GZIP压缩,可以添加浏览器本地缓存
-稳定性高:宕机的概率非常小
-master/worker结构:一个master进程,生成一个或者多个worker进程
-接收用户请求是异步的:浏览器将请求发送到nginx服务器,它先将用户请求全部接收下来,再一次性发送给后端web服务器,极大减轻了web服务器的压力
-一边接收web服务器的返回数据,一边发送给浏览器客户端
-网络依赖性比较低,只要ping通就可以负载均衡
-可以有多台nginx服务器
-事件驱动:通信机制采用epoll模型
为什么Nginx性能这么高?
事件处理机制,异步非阻塞事件处理机制:运用了epoll模型,提供了一个队列,排队解决
正向代理
一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理
正向代理总结就一句话:代理端代理的是客户端
反向代理
反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求,发给内部网络上的服务器
并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器
反向代理总结就一句话:代理端代理的是服务端
动态资源、静态资源分离
动态资源、静态资源分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路
动态资源、静态资源分离简单的概括是:动态文件与静态文件的分离
为什么要做动、静分离?
提高用户访问静态代码的速度,降低对后台应用访问,可以将静态资源放到nginx中,动态资源转发到tomcat服务器中
负载均衡
负载均衡即是代理服务器将接收的请求均衡的分发到各服务器中
负载均衡主要解决网络拥塞问题,提高服务器响应速度,服务就近提供,达到更好的访问质量,减少后台服务器大并发压力
缓存服务
开启简单的缓存配置,只需要两个指令:proxy_cache_path和proxy_cache。proxy_cache_path配置缓存的存放地址和其他的一些常用配置,proxy_cache指令是为了启动缓存。
#配置nginx负载均衡的服务器列表
upstream mysvr {
#weigth参数表示权值,权值越高被分配到的几率越大
#本机上的Squid开启3128端口
server 192.166.62.42:8063 weight=10;
server 192.166.62.32:8063 weight=10;
}
server {
listen 8065;
server_name mediatool;
location ~*^.+$ { #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
proxy_pass http://mysvr; #请求转向mysvr 定义的服务器列表
}
location / {
root html;
index index.html index.htm;
}
location / {
proxy_cache off; #开启缓存,imooc_cache对应上面keys_zone=imooc_cache:10m ;关闭off
proxy_pass http://imooc;
proxy_cache_valid 200 304 12h; #200和304头信息过期时间12小时
proxy_cache_valid any 10m; #其他过期时间10分钟
proxy_cache_key $host$uri$is_args$args; #定义缓存的key
add_header Nginx-Cache "$upstream_cache_status";#增加一个头信息
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; # 一个服务报错请求下一个
include proxy_params;
}
}
配置单图片服务器
server {
listen 8085;#端口号
server_name 192.166.169.81;#本机
charset utf-8;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
}
location ^~ /person/ {
alias /home/person/;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
负载均衡配置
#配置nginx负载均衡的服务器列表
upstream mysvr {
#weigth参数表示权值,权值越高被分配到的几率越大
#本机上的Squid开启3128端口
server 192.166.62.42:8063 weight=10;
server 192.166.62.32:8063 weight=10;
}
server {
listen 8065;
server_name mediatool;
location ~*^.+$ { #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
proxy_pass http://mysvr; #请求转向mysvr 定义的服务器列表
}
location / {
root html;
index index.html index.htm;
}
}