Nginx面试题

什么是Nginx?

nginx是一个web服务器,反向代理服务器,缓存服务器

为什么使用nginx

跨平台,配置简单,非阻塞,高并发连接:处理2-3万并发连接数,官方监测能支持5万并发。

内存消耗小:开启10个nginx才占150M内存,nginx处理静态资源好,消费内存少.

内置的简单检查功能:如果一个服务器宕机,会做一个健康检查,再发送的请求就不会发送到宕机的服务器了,从新将请求提交给其他节点上.
节省带宽:支持gzip压缩,可以添加浏览器本地缓存。

稳定性高:宕机的概率非常小。

接收用户请求是异步的:浏览器将请求发送给nginx服务器,他将用户请求全部接收下来,再一次性发送给后端的web服务器,极大减轻了web服务器的压力,一遍接收web服务器的返回数据,一边发送给浏览器客户端,网络依赖性比较低,只有ping通就可以负载均衡,可以用多台nginx服务器,使用dns做负载均衡,时间驱动,通信机制采用epoll模型。

nginx是如何处理一个请求的?

首先,nginx在启动时,会解析配置文件,得到需要监听的端口与ip地址,然后在nginx的master进程里面先初始化好这个监控的socket,再进行listen,然后再fork出多个子进程出来, 子进程会竞争accept新的连接。此时,客户端就可以向nginx发起连接了。当客户端与nginx进行三次握手,与nginx建立好一个连接后,此时,某一个子进程会accept成功,然后创建nginx对连接的封装,即ngx_connection_t结构体,接着,根据事件调用相应的事件处理模块,如http模块与客户端进行数据的交换。最后,nginx或客户端来主动关掉连接,到此,一个连接就寿终正寝了

为什么nginx性能这么高

得益于它的事件处理机制:异步非阻塞事件处理机制,运用了epoll模型,提供了一个队列,排队解决。

nginx的负载均衡算法都要哪些?

nginx的upstream目前支持4种方式的分配

0)轮询:

每次请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

1)weight 权重轮询

指定轮询几率,weight和访问比例成正比,用于后端服务器性能不均的情况。

2)ip_hash

每次请求按访问ip的hash结果分配,这样每个访客固定访问一台后端服务器,可以解决session的问题。

3)fair

按后端服务器的响应来分配请求,响应时间短的优先分配。

4)url_hash

根据url的hash结果分配请求,是url定向到同一服务器,在upstream中加入hash语句后,server语句不能写入weight等其他参数,这种算法一般在后端缓存的时候比较适合。

5)最少连接(least_conn)

下一个请求被分派到活动连接数量最少的服务器

nginx的upstream中的ip_hash和url_hash的区别和特点。

ip_hash:每次请求访问,按照ip的hash结果分配,这样每个访客固定访问一台后端服务器,可以解决session的问题。

url_hash: 根据url的hash结果分配请求,使url定向到同一服务器,在upstream中加入hash语句后,server语句中不能写入weight等其他参数,这种算法一般在后端缓存的时候比较适合。

nginx和apache的区别

轻量级,同样起web服务,比apache占用更少的内存和资源。

抗并发,nginx处理请求是异步非阻塞的,而apache则是阻塞性的,在高并发下nginx能保持低资源,低消耗高性能。

高度模块化的设计,编写模块相对简单。

最核心的区别在于apache是同步多进程模型,一个连接对应一个进程,nginx是异步的,多个连接可以对应一个进程。

Nginx Apache
- nginx是一个基于事件的web服务器 apache是一个基于流程的服务器
所有请求都由一个线程处理 单个线程处理单个请求
nginx避免子进程的概念 apache是基于子进程的
nginx类似于速度 apache类似于功率
nginx在内存消耗和连接方面比较好 apache在内存消耗和连接上没有提高
nginx在负载均衡方面表现较好 当流量到达进程极限时,apache将拒绝新的连接。
对于php来说,nginx可能更可取,因为它支持php apache支持php,python,perl和其他语言使用插件,当应用程序基于python或ruby时,它非常有用。
nginx不支持IBMI和openvms一样的os apache支持更多的os
nginx只具有核心功能 apache提供了比nginx更多的功能
nginx的性能和可伸缩性不依赖于硬件 apache依赖于cpu和内存等硬件组件。

什么是正向代理和反向代理

一个位于客户端与原始服务器之间的服务器,为了从原始服务器取得内容,客户端向代理发送了一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端,客户端才能使用正向代理。正向代理总结一句话就是:代理端代理的是客户端

反向代理服务器作用在服务端,他在服务器端接收客户端的请求,然后将请求分发给具体的服务器进行处理,然后再将服务器的相应结果反馈给客户端,nginx就是一个反向代理服务器软件。

负载均衡

负载均衡即是代理服务器将接收的请求均衡的分发到各服务器中,负载均衡主要解决网络拥塞问题,提高服务器响应速度,服务就近提供,达到更好的访问质量,减少后台服务器大并发压力。

动态资源,静态资源分离?

动态资源,静态资源分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化的核心思路,动态资源,静态资源分离简单概括是:动态文件和静态文件的分离。

为什么要做动静分离?

在我们的软件开发中,有些请求是需要后台处理的,有些请求不需要后台处理,这些不需要经过后台处理的文件称为静态文件,因此我们后台处理忽略静态文件。这会有人说那我后台忽略静态文件不就完了吗,当然这是可以的,但是这样后台的请求次数明显增多了,在我们对资源的响应速度有要求的时候,我们应该使用这种动静分离的策略去解决,动,静分离将网站静态资源与后台分开部署,提高用户访问静态代码的速度,降低对后台应用的访问,这里我们将静态资源放在nginx中,动态资源转发到tomcat服务器中。

请解释ngx_http_upstream_module作用是什么?

允许定义一组服务器。它们可以在指令proxy_passfastcgi_passmemcached_pass中被引用到。

请解释什么是C10K问题?

C10K问题是指无法同时处理大量客户端的网络套接字。

请陈述stub_status和sub_filter指令的作用是什么?

stub_status 指定:该指令用于了解nginx当前状态,如当前的活动链接,

接受和处理当前读/写/等待的总数。

sub_filter指定:它用于搜索和替换响应中的内容,并快速修复陈旧的数据

解释nginx是否支持将请求压缩到上游

你可以使用nginx模块gunzip将请求压缩到上游,gunzip模块是一个过滤器,他可以对不支持gzip编码方法的客户机或服务器使用内容编码:gzip来解压缩响应。

用Nginx服务器解释-s的目的是什么?

用于运行nginx -s参数的可执行文件

请列举nginx的一些特性?

跨平台:可以在unix系统编译运行,而且有windows的移植版本。

配置简单:非常的简单,易上手。

非阻塞高并发连接:数据复制时,磁盘I/O的第一阶段是非阻塞的。官方测试能支持5万并发连接,实际生产中能跑2-3万并发连接数。发送报文是,nginx是一边接受web服务器的返回数据,一边把数据发送给客户端浏览器。

自带健康检查:当有服务器宕机后,新的请求就不会发送到这台机器上了,而是发送到其他节点。

节省带宽:支持gzip压缩,开启开启浏览器缓存。

网络依赖性低,理论上只要能够ping通就可以实施负载均衡,而且可以有效区分内网、外网流量。

内存消耗少,稳定性高:开启10个nginx消耗内存125M,可以很好的处理静态资源,内存消耗少。宕机率很低。

在nginx中,如何使用未定义的服务器名称来阻止处理请求?

只需将请求删除的服务器就可以定义为:

服务器名被保留一个空字符串,他在没有主机头字段的情况下匹配请求,而一个特殊的nginx的非标准代码被返回,从而终止连接。

请列举Nginx服务器的最佳用途

nginx服务器的最佳用法是在网络上部署动态HTTP内容,使用SCGI,WSGI应用程序服务器,用于脚本的fastcgi处理程序,他还可以作为负载均衡器。

请解释nginx服务器上的master和worker进程分别是什么?

nginx的master和worker进程之间的关系,就像是一家饭店的服务员和老板的关系。

加入有一个饭店有多个服务员,而管理这些服务员的老板一个人,其中老板负载对外招揽业务,而服务员负责干活,如果一个服务员接待不完这些客人,老板会把随后的客人交给其他的服务员接待。

在这里,老板就属于master进程,客户端所有的请求都是由master来接收,服务员就相当于worker进程。

生产中如何设置worker进程的数量呢?

在有多个cpu的情况下,可以设置多个worker,worker进程的数量可以设置到和cpu的核心数一样多,如果在单个cpu上起多个worker进程,那么操作系统会在多个worker之间进行调度,这种情况会降低系统性能,如果只有一个cpu,那么只启动一个worker进程就可以了。

Last-Modified,Expires,Max-age,Etag他们的含义,作用于浏览器端的是那些?作用于服务端的是那些?

Last-Modified:标记浏览器请求的URL对应的文件在服务器端最后被修改的时间。

Expires:需要和last-Modified结合使用,用于控制请求文件的有效日期,当请求数据在有效期内时客户端从缓存请求数据而不是服务器端,当缓存中数据失效或过期,才决定从服务器更新数据。

Max-age:指定的是文档被访问后的存活时间,这个时间是一个相对值(比如3600s),相对的是文档第一次被请求时服务器记录的request_time(请求时间)

Etag:服务器响应时,给url标记,并在http响应头中将其传送到客户端。

cookie和session区别?

共同:

存放用户信息。存放的形式:key-value格式 变量和变量内容键值对。

区别:

cookie

存放在客户端浏览器

每个域名对应一个cookie,不能跨跃域名访问其他cookie

用户可以查看或修改cookie

http响应报文里面给你浏览器设置

钥匙(用于打开浏览器上锁头)

session:

存放在服务器(文件,数据库,redis)

存放敏感信息

锁头

为什么nginx不使用多线程?

Apache:创建多个进程和线程,而每个进程或线程都会为其分配cpu和内存(线程要比进程小的多,多以worker支持比perfork高的并发),并发多大会消耗光服务器资源。

Nginx:采用单线程来异步非阻塞处理请求(管理员可以配置nginx主进程的工作进程数量)(epoll),不会为每个请求分配cpu和内存资源,节省了大量资源,同时也减少了大量的cpu的上下文切换。所以才使得nginx支持更高的并发。

nginx常见的优化配置有哪些?

安全优化:
隐藏nginx版本信息优化:修改nginx配置文件实现优化。

server_tokens off;

修改nginx进程用户信息:

修改默认进程用户nginx为其他,如www.

修改nginx服务上传文件限制:

client_max_body_size 设置客户端请求报文主体最大尺寸,用户上传文件 大小。

nginx图片及目录防盗链解决方法

根据HTTP referer实现防盗链

用户从哪里跳转过来的(通过域名)referer控制

根据cookie防盗链

nginx站点目录文件及目录权限优化

只将用户上传数据目录设置为755用户和组使用nginx

其余目录和文件为755/644,用户和组使用root

使用普通用户启动nginx

利用nginx -c参数启动nginx多实例,使master进程让普通用户管理。普通用户无法使用1-1024端口。使用iptables转发。

控制nginx并发连接数
控制客户端请求nginx的速率
性能优化:
1.调整worker_processes

指nginx要生成的worker数量,一般和cpu的核心数设置一致,高并发可以和cpu核心2倍.

cat /proc/cpuinfo

2.优化nginx服务进程均匀分配到不同cpu进行处理。

利用worker_cpu_affinity进行优化让cpu的每颗核心平均。

3.优化nginx事件处理模型

利用use epoll参数修改事件模型为epoll模型。

事件模型指定配置参数放置在event区块中

4.优化nginx单进程客户端连接数

利用worker_connections连接参数进行调整

用户最大并发连接数=worker进程数*worker连接数

5.优化nginx服务进程打开文件数

利用worker_rlimit_nofile 参数进行调整

6.优化nginx服务数据高效传输模式。

利用sendfile on开启高速传输模式。

tcp_nopush on 表示将数据积累到一定的量再进行传输。

tcp_nopush on 表示将数据信息进行快速传输

7.优化nginx服务超时信息。

keepalive_timeout 优化客户端访问 nginx服务端超时时间。

http协议特点:连接断开后会给你保留一段时间

nginx常用模块

access 访问模块

auth 认证模块

gzip 压缩模块

proxy 代理模块

upstream 负载均衡

rewrite 重写模块

log 日志模块

limit conn现在用户访问并发连接

ssl模块

autoindex 开启目录浏览

location匹配的优先级别

1.首先精准匹配 =

2.其次前缀匹配 ^~

3.其次是按文件中的顺序正则匹配

4.然后配置不带任何修饰的前缀匹配

5.最后交给/ 通用匹配

6.当有匹配成功时,停止匹配,按当前匹配规则处理请求。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • 什么是Nginx Nginx是一个web服务器和反向代理服务器,用于HTTP、HTTPS、SMTP、POP3和IM...
    安息园阅读 8,084评论 0 4
  • nginx做一项基础工具,对一个程序猿的重要性却是不言而喻的,本文将汇总面试和工作中的一些常用命令和考点,持续更新...
    聂云⻜阅读 860评论 0 0
  • 什么是Nginx? Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器N...
    jiangmo阅读 2,537评论 1 9
  • Nginx简介 解决基于进程模型产生的C10K问题,请求时即使无状态连接如web服务都无法达到并发响应量级一万的现...
    魏镇坪阅读 1,997评论 0 9
  • 走出痛苦的唯一方法就是经历痛苦,你必须感受到痛苦的存在。不是说停留在伤痛中,也不是说用伤痛的方式生活。伤痛时还能感...
    裸熊兜Doris阅读 192评论 0 0