nginx使用手册+基本原理+优缺点
閱讀本文約花費: 4 (分鐘)
一、nginx优点
1.反向代理
1、正向代理: 客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。
server不知道client是谁
2、反向代理:客户端请求服务器,中间也是经过一个代理服务器,客户端访问代理服务器就好像访问目标服务器一样。同时代理服务器将请求转发到后端具体服务器。
客户端不知道自己具体访问的服务器是谁
3、总结 https://blog.csdn.net/wnvalentin/article/details/88171847
正向代理是对客户端的代理,由客户端设立,客户端了解代理服务器和目标服务器,但目标服务器不了解真正的客户端是谁;使用正向代理可达到 突破访问限制、提高访问速度、对服务器隐藏客户端IP等目的;
反向代理是对服务器的代理,由服务器设立,客户端不了解真正的服务器是谁,使用反向代理可达到负载均衡、保障服务端安全、对客户端隐藏服务器IP等目的。
2.负载均衡
集群平摊请求压力
负载均衡策略:
- 轮询 :平均访问(默认方式)
upstream myserver{ ip_hash; server 192.168.17.129:8000; server 192.168.17.129:8001; server 127.0.0.1:7071 down; #不参与负载均衡 server 127.0.0.1:7070 backup; #备份server 只有其他都忙了才访问 }
- 权重
upstream myserver{ server 192.168.17.129:8000 weight 1; server 192.168.17.129:8001 weight 2; }
- IP hash :每个ip分配一个固定的服务器
upstream myserver{ ip_hash; server 192.168.17.129:8000; server 192.168.17.129:8001; }
- URL hash
upstream myserver{ server 192.168.17.129:8000; server 192.168.17.129:8001; hash $request_uri; hash_method crc32; #hash 方法 }
- fair 根据响应时间来访问,哪个机器响应快就哪个
upstream myserver{ server 192.168.17.129:8000; server 192.168.17.129:8001; fair; }
server模块的配置:
server{ listen 80; server_name 192.168.17.129; location /{ proxy_pass http://myserver; #前面upstream的名字 } }
3.动静分离
动态页面和静态页面分开部署,把动态页面的服务器性能弄的好一些,静态页面的服务器可以差一些,并且可以设置缓存。
二、基本命令
- nginx 启动
- nginx -v版本号
- nginx -s stop 关闭
- nginx -s reload 重新加载配置文件
三、配置文件
1、root和alias的区别
- root:【指定机器根路径】
location /appImg/{ root /home/nginx; }
这个location相当于访问服务器上的文件路径: /home/nginx/appImg/ 。
- alias:【别名】
location /appImg/{ alias /home/nginx/; }
这个alias代表了/appimg/ = /home/nginx/
3、worker_connections 和 worker_processes
设置并发数和连接数
连接数:
静态资源:2请求静态资源1返回静态资源2clientnginx
反向代理:4请求动态资源1请求后端服务2返回数据3返回动态资源4clientnginxserver
四、基本原理
- master管理者:管理监控
- worker工作者 :连接
每个worker都维护一个线程处理请求
worker_processes设置的数量和cpu核数最好相等,每个worker都是一个独立的进程
3个worker
root 20789 1 0 10:19 ? 00:00:00 nginx: master process nginx nobody 22281 20789 0 10:47 ? 00:00:00 nginx: worker process nobody 22282 20789 0 10:47 ? 00:00:00 nginx: worker process nobody 22283 20789 0 10:47 ? 00:00:00 nginx: worker process root 22319 20514 0 10:48 pts/1 00:00:00 grep --color=auto nginx
1个worker
root 20789 1 0 10:19 ? 00:00:00 nginx: master process nginx nobody 22376 20789 0 10:49 ? 00:00:00 nginx: worker process root 22378 20514 0 10:49 pts/1 00:00:00 grep --color=auto nginx
master-worker架构的优点
- 支持热部署reload,一个worker修改config,其他继续处理请求
- 进程独立,每个worker都是一个进程,不会造成服务中断