【服务器】nginx面试题
目录
-
什么是Nginx
-
为什么要用Nginx
-
为什么Nginx性能这么高
-
Nginx怎么处理请求
-
什么是正向代理和反向代理
-
Nginx的优缺点
-
Nginx应用场景
-
Nginx的目录结构有哪些
-
Nginx静态资源
-
如何用Nginx解决前端跨域问题
-
Nginx虚拟主机
-
基于虚拟主机配置域名
-
基于端口的虚拟主机
-
location的作用是什么
-
location的语法
-
location正则示例
-
限流怎么做的
-
限流有三种:
-
三种限流算法
-
正常限制访问频率(正常流量)
-
突发限制访问频率(突发流量)
-
限制并发连接数
-
漏桶算法
-
令牌桶算法
-
动静分离
-
为什么要做动静分离
-
Nginx怎么做的动静分离
-
Nginx负载均衡的算法怎么实现的?策略有哪些?
-
轮询(默认)
-
权重 weight
-
ip_hash( IP绑定)
-
fair(第三方插件)
-
url_hash(第三方插件)
-
Nginx配置高可用性怎么配置
-
Nginx怎么判断别IP不可访问
-
怎么限制浏览器访问?
-
Rewrite全局变量是什么?
什么是Nginx
Nginx是一个轻量级/高性能的反向代理服务器,它实现非常高效的反向代理、负载均衡。它可以处理2-3万并发连接数,官方监测能支持5万并发,现在国内使用网站用户有很多,例如:新浪、网易、腾讯等。
为什么要用Nginx
-
跨平台、配置简单、方向代理、高并发:处理2-3万并发连接数,官方监测能支持5万并发连接,内存消耗少:开启10个nginx才占150M内存,nginx处理静态文件好,耗费内存少。
-
Nginx内置健康检查功能:如果一个服务器down机,会做一个健康检查,再发送的请求就不会发送到down机的服务器。重新将新的请求提交到其它节点上。
-
使用Nginx还能1、节省带宽:支持GZIP压缩,可以添加浏览器本地缓存;2、稳定性高:宕机的概率非常小;3、接受用户请求是异步的。
为什么Nginx性能这么高
因为它的事件处理机制:异步非阻塞时间处理机制,运用了epoll模型,提供了一个队列,排队解决
Nginx怎么处理请求
nginx接收到一个请求后,首先有listen和server_name指令匹配server模块,再匹配server模块里的location,location实际就是实际地址
什么是正向代理和反向代理
-
正向代理:指代理机器代理的是客户端,明确目标地址
-
反向代理:指代理的的是服务端,对用户透明,用户并不清楚资源是有后端哪台服务器响应。
Nginx的优缺点
-
优点
1、占用内存小,可实现高并发连接,处理响应快
2、可实现http服务器、虚拟主机、反向代理、负载均衡;
3、Nginx配置简单
4、可以不暴露真实的服务器IP地址 -
缺点
动态处理差:nginx处理静态文件好,耗费内存少,但是处理动态页面则很鸡肋,现在一般前端用nginx作为反向代理抗压
Nginx应用场景
1、http服务器:Nginx是一个http服务,可以独立提供http服务。可以做网页静态服务器。
2、虚拟主机:可以实现一台服务器虚拟出多个网站,例如个人网站使用的虚拟机。
3、反向代理及负载均衡:当网站访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群,可以使用nginx做反向代理来实现。并且多台服务器可以平均分担负载,不会某台服务器出现负载高而另外一台服务器闲置的情况。
Nginx的目录结构有哪些
Nginx静态资源
静态资源访问,就是存放在nginx的html页面,我们可以自己编写
如何用Nginx解决前端跨域问题
使用Nginx转发请求。把跨域的接口写成掉本域的接口,然后将这些接口转发到真正的请求地址
Nginx虚拟主机
-
基于域名的虚拟主机:通过域名来区分虚拟主机————应用:外部网站
-
基于端口的虚拟主机:通过端口来区分虚拟主机————应用:公司内部网站,外部网站的管理后台
-
基于IP的虚拟主机。
基于虚拟主机配置域名
需要建立/data/www /data/bbs目录,windows本地hosts添加虚拟主机ip地址对应的域名解析;对应域名网站目录下新增index.html文件
基于端口的虚拟主机
使用端口来区分,浏览器使用域名或IP地址:端口号访问
location的作用是什么
location指令的作用是根据用户请求的URI来执行不同的应用,也就是根据用户请求的URL进行匹配,匹配成功即进行相关的操作。
location的语法
location正则示例
限流怎么做的
Nginx限流就是限制用户请求速度,防止服务器压力过大
限流有三种:
-
正常限制访问频率(正常流量)
-
突发限制访问频率(突发流量)
-
限制并发连接数
Nginx限流都是基于漏桶流算法,下面会进行说明
三种限流算法
正常限制访问频率(正常流量)
-
限制一个用户发送的请求,Nginx多久接收一个请求
-
Nginx中使用ngx_http_limit_req_module模块来限制访问频率,限制的原理实质是基于漏桶算法原理来实现的。在nginx.conf配置文件中可以使用limit_req_zone命令及limit_req命令限制单个IP的请求处理频率。
1r/s代表1秒一个请求,1r/m一分钟接收一个请求, 如果Nginx这时还有别人的请求没有处理完,Nginx就会拒绝处理该用户请求。
突发限制访问频率(突发流量)
-
限制一个用户发送的请求,Nginx多久接收一个;
-
上面的配置一定程度可以限制访问频率,但是也存在着一个问题:如果突发流量超出请求被拒绝处理,无法处理活动时候的突发流量,这时候应该如何进一步处理呢?Nginx提供burst参数结合nodelay参数可以解决流量突发的问题,可以设置能处理的超过设置的请求数外能额外处理的请求数。我们可以将之前的例子添加burst参数以及nodelay参数:
为什么就多了一个 burst=5 nodelay呢?多了这个可以代表Nginx对于一个用户的请求会立即处理前五个,多余的就慢慢来落,没有其他用户的请求过来就处理你的,有其他的请求的话Nginx就漏掉不接受你的请求
限制并发连接数
Nginx中的ngx_http_limit_conn_module模块提供了限制并发连接数的功能,可以使用limit_conn_zone指令以及limit_conn执行进行配置。接下来我们可以通过一个简单的例子来看下
上面配置了单个IP同时并发连接数最多只能10个连接,并且设置了整个虚拟服务器同时最大并发数最多只能100个链接。当然,只有当请求的header被服务器处理后,虚拟服务器的连接数才会计数。刚才有提到过Nginx是基于漏桶算法原理实现的,实际上限流一般都是基于漏桶算法和令牌桶算法实现的。接下来我们来看看两个算法的介绍:
漏桶算法
漏桶算法是网络世界中流量整形或速率限制时经常使用的一种算法,它的主要目的是控制数据注入到网络的速率,平滑网络上的突发流量。漏桶算法提供了一种机制,通过它,突发流量可以被整形以便为网络提供一个稳定的流量。也就是我们刚才所讲的情况。漏桶算法提供的机制实际上就是刚才的案例:突发流量会进入到一个漏桶,漏桶会按照我们定义的速率依次处理请求,如果水流过大也就是突发流量过大就会直接溢出,则多余的请求会被拒绝。所以漏桶算法能控制数据的传输速率。
令牌桶算法
令牌桶算法是网络流量整形和速率限制中最常使用的一种算法。典型情况下,令牌桶算法用来控制发送到网络上的数据的数目,并允许突发数据的发送。Google开源项目Guava中的RateLimiter使用的就是令牌桶控制算法。令牌桶算法的机制如下:存在一个大小固定的令牌桶,会以恒定的速率源源不断产生令牌。如果令牌消耗速率小于生产令牌的速度,令牌就会一直产生直至装满整个令牌桶。
动静分离
为什么要做动静分离
-
Nginx是当下最热的Web容器,网站优化的重要点在于静态化网站,网站静态化的关键点则是是动静分离,动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们则根据静态资源的特点将其做缓存操作。
-
让静态的资源只走静态资源服务器,动态的走动态的服务器
-
Nginx的静态处理能力很强,但是动态处理能力不足,因此,在企业中常用动静分离技术。
-
对于静态资源比如图片,js,css等文件,我们则在反向代理服务器nginx中进行缓存。这样浏览器在请求一个静态资源时,代理服务器nginx就可以直接处理,无需将请求转发给后端服务器tomcat。 若用户请求的动态文件,比如servlet,jsp则转发给Tomcat服务器处理,从而实现动静分离。这也是反向代理服务器的一个重要的作用。
Nginx怎么做的动静分离
只需要指定路径对应的目录。location/可以使用正则表达式匹配。并指定对应的硬盘中的目录。如下:(操作都是在Linux上)
-
1、创建目录
-
2、进入目录
-
3、放一张照片上去
-
4、重启 nginx
-
5、打开浏览器 输入 server_name/image/1.jpg 就可以访问该静态图片了
Nginx负载均衡的算法怎么实现的?策略有哪些?
-
为了避免服务器崩溃,大家会通过负载均衡的方式来分担服务器压力。将对台服务器组成一个集群,当用户访问时,先访问到一个转发服务器,再由转发服务器将访问分发到压力更小的服务器。
-
Nginx负载均衡实现的策略有以下五种:
轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端某个服务器宕机,能自动剔除故障系统。
权重 weight
weight的值越大分配到的访问概率越高,主要用于后端每台服务器性能不均衡的情况下。其次是为在主从的情况下设置不同的权值,达到合理有效的地利用主机资源。
权重越高,在被访问的概率越大,如上例,分别是20%,80%。
ip_hash( IP绑定)
每个请求按访问IP的哈希结果分配,使来自同一个IP的访客固定访问一台后端服务器,并且可以有效解决动态网页存在的session共享问题
fair(第三方插件)
-
必须安装upstream_fair模块。
-
对比 weight、ip_hash更加智能的负载均衡算法,fair算法可以根据页面大小和加载时间长短智能地进行负载均衡,响应时间短的优先分配。
哪个服务器的响应速度快,就将请求分配到那个服务器上。
url_hash(第三方插件)
-
必须安装Nginx的hash软件包
-
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,可以进一步提高后端缓存服务器的效率。
Nginx配置高可用性怎么配置
-
当上游服务器(真实访问服务器),一旦出现故障或者是没有及时相应的话,应该直接轮训到下一台服务器,保证服务器的高可用
-
Nginx配置代码:
Nginx怎么判断别IP不可访问
怎么限制浏览器访问?
Rewrite全局变量是什么?
猜你喜欢
- 【支付宝】支付宝服务商支付
- 通过第三方应用授权,服务商在取得商家授权后,可以代商家调用支付宝开放接口,以完成相应的业务逻辑(如代替商家发起当面付的收单请求等)。 授权采用标准的 OAuth2.0 流程,要进行第三方代调用,服务商需要在第三方应用中添加对应功能并获得商家授权,本文介绍服务商的第三方应用如何取得商家应用的授权。
- 【行业动态】TIOBE4月榜单发布:C/C++深受内存安全影响、PHP辉煌不再!
- 4 月 TIOBE 编程语言榜单已发布,一起来看看本月有什么值得关注的新变化吧!01 C、C++ 深受“内存安全”的影响相较上个月,4 月 TIOBE 榜单的 Top 5 并没有太大变化,依旧是 Python、C、C++、Java、C#。不过,值得注意的是,Top 5 之列只有排名第一的 Python 是继续保持着正向增长的趋势,比上个月上涨了 0.78%,达到 16.41% 的市场份额。一直以来,Python 凭借简洁的语法和清晰的代码结构使得初学者能够快速上手,不仅在 Web 开发
- 【网络】开源协议有哪些,都有什么差异
- 在IT行业中,开源协议是用来定义如何使用、修改、分享和分发软件的法律条款。不同的开源协议在保留版权、允许的使用方式、对衍生作品的要求以及对分发的限制等方面有所不同。以下是一些常用的开源协议及其主要特点:1. MIT License (MIT)特点:非常宽松,基本上允许任何形式的使用、修改和再分发,只要保留版权声明。适用场景:适合那些希望自己的代码被广泛使用,且不想对使用者施加太多限制的项目。2. GNU General Public License (GPL)特点:要求任何发布/分发的衍生作品也
- 【支付宝】手机浏览器跳转打开支付宝APP
- 手机浏览器跳转打开支付宝APP alipays://platformapi/startapp?appId=20000067&url= url后面跟上要跳转的链接
- 【服务器】nginx面试题
- 目录什么是Nginx为什么要用Nginx为什么Nginx性能这么高Nginx怎么处理请求什么是正向代理和反向代理Nginx的优缺点Nginx应用场景Nginx的目录结构有哪些Nginx静态资源如何用Nginx解决前端跨域问题Nginx虚拟主机基于虚拟主机配置域名基于端口的虚拟主机location的作用是什么location的语法location正则示例限流怎么做的限流有三种:三种限流算法正常限制访问频率(正常流量)突发限制访问频率(突发流量)限制并发连接数漏桶算法令牌桶算法动静分离为什么要做动静
- 【其它】32位与64位系统之间有什么区别
- 首先,我们来解释一下32位和64位究竟意味着什么。这两种术语常用于描述计算机的操作系统架构。简而言之,32位系统表示其处理器一次能处理32位数据,而64位系统则意味着处理器每次能处理64位数据。这种差异带来了诸多方面的不同,包括系统性能、支持内存容量以及支持的软件类型等。接下来,我们将深入探讨这些差异。
- 【网络】国内十大API数据服务平台
- 一、数据宝 https://www.chinadatapay.com/数据宝是国内领先的国有数据资产代运营服务商,数据丰富多元,覆盖人、企、车、路、能源、环境等数百个数据因子维度,专注于为国有数据资源方提供数据治理、产品研发、交易流通、应用变现等数据增值代运营服务,是国内少数同时具备了“国资参股、政府监管扶持、市场化运作、大数据资产交易合法经营资质”属性的大数据“国家队”。二、天眼数聚 https://www.tianyandata.cn/天眼数聚是一家专注于大数据服务的技术
- 【网络】七牛云存储创建空间并配置自定义域名
- 1. 创建空间bucket按规则填写名称,选择区域即可,至于共有还是私有,根据自己业务内容而定。空间创还能成功后会提示绑定自定义域名,点击立即绑定,或者在空间管理里面点击绑定域名。2. 添加域名在添加域名页面,填写自定义域名,系统会自动判断域名情况,如果未备案,默认只能选择海外,如果已备案,默认选择中国大陆。如果是未备案域名,对应的存储空间也只能选择海外空间,都由系统自动判定。这里只演示已备案域名,我的域名是在阿里云备案的。域名创建成功后,如下图,会显示CNAME未配置,复制CNAME对应的值,