nginx的一些笔记

一、正向代理和反向代理

1.正向代理:

例如翻墙服务器,翻墙的方式主要是找到一个可以访问国外网站的代理服务器,我们将请求发送给代理服务器,代理服务器去访问国外的网站,然后将访问到的数据传递给我们!

正向代理最大的特点是客户端非常明确要访问的服务器地址;服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端;正向代理模式屏蔽或者隐藏了真实客户端信息。

正向代理是代理了客户端。

2.反向代理:

一个大型网站能处理高并发需求已经成为最基本的要求,此时单凭一台服务器已经不能处理大量的请求,于是出现了分布式部署,把请求分发给多台服务器来处理高并发。

多个客户端给服务器发送的请求,nginx服务器接收到之后,按照一定的规则分发给了后端的业务处理服务器进行处理了。此时客户端是明确的,但是请求具体由哪台服务器处理的并不明确了,nginx扮演的就是一个反向代理角色。

反向代理是代理了服务器。

二、负载均衡

nginx作为反向代理服务器时,按照一定的规则把请求分发给其他代理服务器,以保证服务器集群中的各台服务器的压力相对平衡,这种规则叫做 负载均衡 。负载均衡的几种模式如下

  1. 轮询(默认):每个请求按时间顺序逐一分配到不同的后端服务器;

  2. ip_hash:每个请求按访问IP的hash结果分配,同一个IP客户端固定访问一个后端服务器。可以保证来自同一ip的请求被打到固定的机器上,可以解决session问题。

  3. url_hash:按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器。后台服务器为缓存的时候效率。

  4. fair:这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。Nginx本身是不支持 fair的,如果需要使用这种调度算法,必须下载Nginx的 upstream_fair模块。

三、try_files 命令

使用场景:

1.适用于当本地没有明确URL文件时,使用前端路由(例如react-router),这里我们就可以指向前端项目的 index.html 来配合使用。

location / {
    index index.html;
    try_files $uri $uri/ /index.html;
}

2.适用于域名资源紧张的情况下,多条业务线的前端工程共用同一个域名,在该域名下使用子目录区分各项目。例如:www.a.com/proj1/ 下存放工程1,www.a.com/proj2/ 下存放工程2。

location /proj1 {
    try_files $uri $uri/ /proj1/index.html;
}
 

location /proj2 {
    try_files $uri $uri/ /proj2/index.html;
}

区分两个工程之后,开始匹配各自的前端路由,例如:路径 www.a.com/proj2/page1 ,匹配到的就是 proj2 项目下的 /proj2/page1 路由。

评论 抢沙发

表情
  1. #1

    来自辽宁沈阳的用户 16天前
    有发布到github吗?

  2. #2

    来自安徽合肥的用户 28天前
    大神 听说你又有才 人又帅,明明可以靠脸吃饭,可是你偏要靠才华,鼓励师都被你撩了我们怎么办

  3. #3

    来自湖北武汉的用户 28天前
    优秀,加油!