【干货】又是一年跳槽季!Nginx 10道核心面试题及解析
Nginx是一款轻量级的高性能Web服务器和反向代理服务器,由俄罗斯的Igor Sysoev开发。它具有占用资源少、高并发、稳定性高等优点,被广泛应用于互联网领域。在Nginx的面试过程中,面试官通常会提出一些核心问题,本文将介绍一些常见的Nginx核心面试题及其解答。
1 Nginx的主要特点是什么?
Nginx的主要特点包括:
- 高性能:Nginx采用异步非阻塞的处理方式,具有高并发和高效率的特点。
- 轻量级:Nginx的代码体积小、占用系统资源少,适合在内存有限的环境中使用。
- 可扩展性:Nginx的模块化设计,使得用户可以根据需求灵活扩展功能。
- 可靠性:Nginx稳定性高,可以在高负载、高并发的环境中保持稳定。
- 反向代理功能:Nginx支持反向代理,能够提高Web应用的可用性和可靠性。
- 负载均衡功能:Nginx支持多种负载均衡算法,能够实现高效的请求分发。
2 Nginx的安装和配置步骤是什么?
Nginx的安装和配置步骤一般包括以下几个步骤:
- 下载Nginx源码:从Nginx官网下载对应版本的Nginx源码。
- 编译安装Nginx:使用编译器编译Nginx源码,并进行安装。
- 配置Nginx:修改Nginx的配置文件nginx.conf,配置监听端口、虚拟主机、反向代理等相关参数。
- 启动Nginx:执行命令启动Nginx服务。
3. Nginx的反向代理和正向代理有什么区别?
反向代理和正向代理都是代理服务器,但两者的作用和方式不同:
- 反向代理:反向代理服务器的作用是隐藏服务器的真实IP地址,客户端向反向代理服务器发送请求,反向代理服务器再向目标服务器发送请求并将响应结果返回给客户端。反向代理通常用于负载均衡、提高Web应用的可用性和可靠性。
- 正向代理:正向代理服务器的作用是代理客户端向目标服务器发送请求,客户端将请求发送给正向代理服务器,正向代理服务器再将请求发送给目标服务器,并将响应结果返回给客户端。正向代理通常用于绕过访问限制、隐藏客户端IP等
4. Nginx的负载均衡有哪些算法?各自的优缺点是什么?
Nginx的负载均衡算法包括:
- 轮询(Round Robin)算法:将请求依次分配给不同的服务器,依次轮流使用每个服务器。轮询算法简单、均衡,但当服务器负载不均衡时,可能会导致某些服务器的负载过高。
- IP Hash算法:将请求根据客户端IP的hash值分配给不同的服务器,同一IP的请求总是分配到同一个服务器上,可以保证某个客户端的请求都由同一台服务器处理,保证session不会丢失。但当服务器数量变动时,会导致大量请求重新分配。
- 最小连接数(Least Connections)算法:将请求分配给当前连接数最少的服务器,保证负载均衡的同时,也保证服务器的负载均衡。但此算法需要不断地监控服务器连接数,对性能有一定的影响。
- 加权轮询(Weighted Round Robin)算法:将服务器按照权重值进行分配,权重越高的服务器会得到更多的请求。该算法可以根据服务器的处理能力分配请求,但需要人工设定权重值。
- 加权最小连接数(Weighted Least Connections)算法:将服务器按照权重值和连接数进行分配,权重值越高的服务器会得到更多的请求,同时也保证当前连接数最少的服务器得到请求。该算法可以更好地实现动态负载均衡。
5. Nginx的进程模型是什么?有哪些优点?
Nginx采用异步非阻塞的I/O多路复用事件驱动模型,可以同时处理大量的并发请求,其进程模型包括:
- Master进程:负责启动和关闭Worker进程,以及管理Nginx的主配置文件和全局变量。
- Worker进程:实际处理请求的进程,每个Worker进程独立处理连接,可以同时处理多个请求。
Nginx的进程模型有以下优点:
- 资源占用少:Nginx的Master进程仅负责管理,不处理连接,占用资源少。
- 可扩展性强:可以通过增加Worker进程来扩展处理能力。
- 并发能力强:采用I/O多路复用技术,能够处理大量的并发连接。
- 稳定性高:Worker进程之间互相独立,一个进程的崩溃不会影响其他进程。
6. 如何优化Nginx的性能?
优化Nginx的性能可以从以下方面入手:
- 调整Worker进程数:根据服务器的CPU核心数和预计的并发连接数,适当调整Worker进程数,以充分利用服务器资源。
- 调整TCP连接参数:修改TCP的缓冲区大小、TCP连接的超时时间等参数,以提高网络传输效率。
- 启用文件缓存:将经常访问的静态文件缓存到内存中,可以减少对磁盘的访问,提高读取速度。
- 启用gzip压缩:开启gzip压缩功能,可以减小响应数据的传输大小,提高网站的响应速度。
- 使用缓存技术:使用反向代理缓存技术、FastCGI缓存技术等,可以减少对后端应用服务器的访问,提高网站的响应速度。
- 使用HTTP2协议:HTTP2协议采用二进制分帧传输,能够提高网站的传输速度和并发量。
- 启用SSL加密:使用SSL加密能够提高网站的安全性,但也会增加CPU的负担,需要合理调整加密算法和参数。
- 启用HTTP缓存:使用HTTP缓存技术可以减少对后端应用服务器的访问,提高网站的响应速度。
总之,优化Nginx的性能需要根据具体的场景和需求来进行调整和优化,需要在充分了解系统性能瓶颈的基础上,进行针对性的优化。
7. Nginx与Apache相比有哪些优势?
Nginx与Apache相比,有以下优势:
- 高性能:Nginx采用异步非阻塞的I/O多路复用事件驱动模型,可以同时处理大量的并发请求,性能比Apache更高。
- 资源占用少:Nginx的Master进程仅负责管理,不处理连接,占用资源少;Worker进程之间互相独立,一个进程的崩溃不会影响其他进程,资源占用更少。
- 可扩展性强:可以通过增加Worker进程来扩展处理能力,更加灵活。
- 配置简单:Nginx的配置文件简单易懂,可以快速修改和配置。
- 功能模块化:Nginx的模块化设计,使得功能模块可以按需启用,减少了系统资源的浪费。
- 安全性高:Nginx支持防火墙、DDoS攻击防御等安全功能,可以提高网站的安全性。
综上所述,Nginx在性能、资源占用、可扩展性、配置简单、功能模块化和安全性等方面都有优势,适合高并发、高性能的场景,相比Apache更加适用于Web服务器。
8. 如何实现Nginx高可用?
Nginx高可用可以通过以下几种方式来实现:
- 负载均衡:将客户端请求分发到多个Nginx服务器上,提高系统的可用性和性能。可以使用第三方的负载均衡软件,如HAProxy、Keepalived等。
- 双机热备:使用主备模式,将两台Nginx服务器设置为主备关系,当主服务器出现故障时,备用服务器立即接管服务,保证系统的连续性和可用性。
- 集群部署:将多个Nginx服务器组成一个集群,通过共享存储、同步数据等技术,实现高可用和负载均衡。
- Docker容器化部署:通过Docker容器化技术,可以快速部署和扩展Nginx服务器,实现高可用和负载均衡。
9. Nginx如何实现反向代理?
Nginx可以通过反向代理技术来实现将请求转发给后端应用服务器,具体步骤如下:
- 配置upstream模块
在Nginx的配置文件中,使用upstream模块定义后端应用服务器的地址和端口号,如:
upstream backend {server 127.0.0.1:8080;server 127.0.0.1:8081;
}
2. 配置location模块
在Nginx的配置文件中,使用location模块定义反向代理的路径和代理规则,如:
location / {proxy_pass http://backend;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;
}
其中,proxy_pass指定后端应用服务器的地址和端口号,proxy_set_header指定请求头信息,可选配置。
3. 重载Nginx配置
在修改Nginx的配置文件后,需要执行命令重载Nginx的配置,如:
nginx -s reload
4. 验证反向代理
在浏览器中访问Nginx的IP地址或域名,即可验证反向代理是否生效。
10. Nginx如何实现动静分离?
Nginx可以通过动静分离技术来提高网站的性能和稳定性,具体步骤如下:
- 将静态文件独立出来
将静态文件(如HTML、CSS、JS、图片、视频等)独立出来,放到专门的文件服务器或CDN上。
2. 配置location模块
在Nginx的配置文件中,使用location模块定义静态文件的路径和代理规则,如:
location /static/ {alias /path/to/static/files/;expires 1d;
}location /media/ {proxy_pass http://backend;proxy_set_header Host
}
其中,alias指定静态文件的目录路径,expires指定浏览器缓存时间,proxy_pass指定后端应用服务器的地址和端口号,可选配置。
3. 重载Nginx配置
在修改Nginx的配置文件后,需要执行命令重载Nginx的配置,如:
nginx -s reload
4. 验证动静分离
在浏览器中访问网站,查看静态文件是否来自专门的文件服务器或CDN,动态内容是否来自应用服务器。同时,可以使用浏览器的开发者工具查看请求和响应的情况。
总结
本文介绍了Nginx的核心面试题,包括Nginx的基本原理、配置文件的结构和语法、常用的Nginx模块和指令、Nginx的高可用和负载均衡、反向代理和动静分离等。掌握这些知识点可以帮助你更好地理解Nginx的工作原理和应用场景,提高Nginx的使用和管理能力。同时,建议结合实际项目经验和实践,深入学习和研究Nginx的高级功能和性能优化,不断提高自己的技术水平和竞争力。
相关文章:
【干货】又是一年跳槽季!Nginx 10道核心面试题及解析
Nginx是一款轻量级的高性能Web服务器和反向代理服务器,由俄罗斯的Igor Sysoev开发。它具有占用资源少、高并发、稳定性高等优点,被广泛应用于互联网领域。在Nginx的面试过程中,面试官通常会提出一些核心问题,本文将介绍一些常见的…...
【线程安全的HashMap有哪些,CurrentHashMap底层是怎么实现线程安全的】
在 Java 中,线程安全的 HashMap 通常有以下几种实现: Collections.synchronizedMap 方法:该方法可以将 HashMap 转换为线程安全的 Map。 Hashtable 类:Hashtable 是一种线程安全的集合类,它与 HashMap 类似࿰…...
C语言-结构体【详解】
一、 结构体的基础知识 结构是一些值的集合,这些值称为成员变量结构的每个成员可以是不同类型的变量 (1)结构体的声明 写法一: 注: 括号后边的分号不能忘结构体末尾可以不创建变量,在主函数中再创建 struc…...
浏览器输入url到页面渲染完成经历了哪些步骤
一、URL解析 这一步比较容易理解,在浏览器地址栏输入url后,浏览器会判断这个url的合法性 ,以及是否有可用缓存,如果判断是 url 则进行域名解析,如果不是 url ,则直接使用搜索引擎搜索 二、域名解析 输入…...
大数据技术之Hadoop(Yarn)
第1章Yarn资源调度器思考:1)如何管理集群资源?2)如何给任务合理分配资源?Yarn是一个资源调度平台,负责为运算程序提供服务器运算资源,相当于一个分布式的操作系统平台,而MapReduce等…...
5.建造者模式
目录 简介 四个角色 应用场景 实现步骤 和工厂模式的区别 简介 建造者模式也叫生成器模式,是一种对象构建模式;它可以把复杂对象的建造过程抽象出来(抽象类别),使这个抽象过程的不同实现方法可以构造出不同表现(属性)的对象;…...
数据库基础-数据库基本概念(1-1)
你好,欢迎来到数据库基础系列专栏,欢迎留言互动哦~ 目录一、数据库基础1. 数据库基本概念1.1 数据库1.2 什么是数据库管理软件1.3 表1.4 行1.5 列和数据类型1.6 主键1.7 什么是 SQL一、数据库基础 1. 数据库基本概念 1.1 数据库 数据库是一个以某种有…...
学习笔记-架构的演进之服务容错策略-服务发现-3月day01
文章目录前言服务容错容错策略附前言 “容错性设计”(Design for Failure)是微服务的一个核心原则。 使用微服务架构,拆分出的服务越来越多,也逐渐导致以下问题: 某一个服务的崩溃,会导致所有用到这个服务…...
采编式AIGC视频生产流程编排实践
作者 | 百度人工智能创作团队 导读 本文从业务出发,系统介绍了采编式 TTV的实现逻辑和实现路径。结合业务拆解,实现了一个轻量级服务编排引擎,有效实现业务诉求、高效支持业务扩展。 全文6451字,预计阅读时间17分钟。 01 背景 近…...
Leetcode23. 合并k个升序链表
一、题目描述: 给你一个链表数组,每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中,返回合并后的链表。 示例 1: 输入:lists [[1,4,5],[1,3,4],[2,6]]输出:[1,1,2,3,4,4,5,6]解释&#…...
从用户出发,互联网产品策划方法论
【一】从用户到需求 产品经理需要具备两个非常重要的技能,一个叫策划,一个叫感知用户。 我们在分析问题的时候往往会说“这么做,我认为用户会怎么怎么样”、“用户会认为这样很不爽”,当我们这样说时,很有可能是把自己当成了用户,用某些特定的情感或记忆代表了用户。 当我…...
STM32 E18-D80NK红外检测
本文代码使用 HAL 库。 文章目录前言一、E18-D80NK 红外传感器:1. E18-D80NK 的介绍2. 电器特性二、红外检测小实验代码讲解三、实验现象总结前言 这篇文章介绍 如何使用 STM32 控制 E18-D80NK 进行红外检测。 一、E18-D80NK 红外传感器: 1. E18-D80N…...
Linux常用命令--进程和计划任务管理
一、程序和进程的关系 1、程序 ①保存在硬盘、光盘等介质中的可执行代码和数据 ②静态保存的代码 2、进程 ①在cpu及内存中运行及进程代码 ②动态执行的代码 ③父(fork)、子进程,每个程序可以创建一个或多个进程 父进程和子进程的区别&am…...
Unity TextMeshPro
Unity TextMeshPro 简介 TextMeshPro(也简称为TMP)号称是Unity的终极文本解决方案,它是Unity 的 UI 文本和旧版文本网格体的完美替代品。 功能强大且易于使用,使用高级文本渲染技术以及一组自定义着色器;提供实质性的视觉质量改进,同时在文本样式和纹理方面为用户提供令人…...
虹科分享| 浅谈HK-Edgility边缘计算平台
上周,我们推出了虹科新品HK-Edgility边缘计算平台以及uCPE解决方案。本篇文章我们再来谈一谈到底什么是边缘计算?为什么需要边缘计算?边缘计算和云计算有什么关系?HK-Edgility边缘计算平台将为您带来什么?一、边缘计算…...
React Router v6详解
旧版本React Router使用方式 BrowserRouter:通过 history 库,传递 history 对象,location 对象Switch:匹配唯一的路由 Route,展示正确的路由组件Route:视图承载容器,控制渲染 UI 组件 新版本R…...
帮助100w人成功入职的软件测试面试常见问题以及答案
测试面试题怎么来设计测试方案根据测试需求(包括功能需求和非功能性需求),识别测试要点,识别测试环境要求,安排测试轮次,根据项目计划和开发计划做整体的测试安排。被测试的特性:通过对需求规格…...
tensorflow2.4--2.回归问题分析
文章目录前言流程案例操作前言 流程 回归问题预测连续值,在某个区间内变动. 常见的线性回归问题模型是yaxb,然而现实世界由于大量的数据偏差以及复杂度,同时还有大量的噪声,往往达不到如此的精确解,实际解决问题时需要考虑噪声的存在 对于噪声,往往我们已经假设了它符合高斯…...
【2023】DevOps、SRE、运维开发面试宝典之Kafka相关面试题
文章目录 1、消息队列的流派2、kafka的优势3、Kafka与Zookeeper的关系4、Kafka消息队列各组件概念5、Kafka消息队列应用场景6、Kafka消息收发的过程7、Kafka消息数据存储概念8、kafka消息的偏移量概念原理9、Kafka消息数据的顺序消费概念原理10、Kafka单播消费消息的原理11、Ka…...
CentOS系统编译安装PHP-5.6.27版本
一、手动安装编译工具: yum install -y gcc gcc-c 二、添加用户和用户组: groupadd web useradd -M -s /sbin/nologin -g web php 三、yum安装依赖: yum -y install libmcrypt libmcrypt-devel mcrypt mhash libxml2-devel libpng-devel l…...
和风SDK查询城市ID(保姆级教程)
android studio版本:2021.2.1例程名:hfserachcityid这几天没什么事做,而且我原来那个“项目”因为免费api不能用了,只能改为和风的免费api,但需要申请,而且还要城市ID,玩天气的基本都知道城市ID这个东西&am…...
暴力递归到动态规划
暴力递归到动态规划 假设有排成一行的n个位置, 记为1~n,n-定大于或等于2。开始时机器人在其中的m位置上(m 一定是1~n中的一个)。如果机器人来到1位置,那么下一步只能往右来到2位置;如果机器人来到n位置, 那么下一步只能…...
Java:Java仍然处于领先地位?
没有多少编程语言能够自吹自擂并持续流行20多年,但Java就是其中之一。Java应用程序不仅局限于web和移动开发,而且给大数据和人工智能留下了深刻的印象。不用多说,让我们讨论一下Java流行的几个原因!!1.实用性根据JamesGosling的说法ÿ…...
虚拟地址空间
本节目录1.如何理解区域划分2.为什么一个变量可以存储两个不同的值?3.深入理解虚拟地址空间为什么要有地址空间?4.理解什么是挂起?1.虚拟地址空间究竟是什么?2.映射关系的维护是谁做的?1.如何理解区域划分 所谓的区域…...
Python基础篇(十五)-- Pygame游戏编程
1 初识Pygame Pygame是一个开源的Python模块,专门用于多媒体应用(如电子游戏)的开发,其中包含对图像、声音、视频、事件、碰撞等的支持。Pygame建立在SDL的基础上,SDL是一套跨平台的多媒体开发库,用C语言实…...
LeetCode 热题 HOT 100 Java 题解 -- Part 2
练习地址 Part 1 : https://blog.csdn.net/qq_41080854/article/details/128829494 LeetCode 热题 HOT 100 Java 题解 -- Part 236. 二叉树的中序遍历 9437. 不同的二叉搜索树 9638. 验证二叉搜索树 9839. 对称二叉树 10140. 二叉树的层序遍历 10241. 二叉树的最大深度 10442.…...
【项目实战】IDEA常用快捷键汇总
一、修改为Eclipse的快捷键 相信很多朋友跟我一样, 都是习惯了eclipse的快捷键,没错,习惯这东西真的很难改!IDEA非常强大,支持我们修改IDEA中的keymap为Eclipse的快捷键!友好又贴心,有没有&…...
更新 TKK 失败,请检查网络连接。谷歌翻译 translation插件不能用解决办法 亲测有效
谷歌翻译无法使用,谷歌回应解释是,谷歌翻译使用率过低,所以选择停止服务。网上也有说法,指出根本原因为,提供API接口的googleapis被墙,这导致js文件和字体资源无法加载。 这里提供两种解决办法 方案一 修…...
SpringBoot整合MybatisPlus多数据源
相信在很多使用MybatisPlus框架的小伙伴都会遇到多数据源的配置问题,并且官网也给出了推荐使用多数据源 (dynamic-datasource-spring-boot-starter) 组件来实现。由于最近项目也在使用这个组件来实现多数据源切换,因此想了解一下该组件是如何运行的&…...
【教程】如何使用Java生成PDF文档?
在如今数字化时代,越来越多的人使用PDF文档进行信息传递和共享。而使用Java生成PDF文档也成为了一个非常重要的技能,因为Java作为一种通用的编程语言,可以在不同的操作系统和平台上运行。下面,我们将为您介绍如何使用Java生成PDF文…...
什么网站做兼职靠谱吗/2022最近比较火的营销事件
身份证过期要到蓟县南所去办理 南所电话:022-29186230 南所地址:天津市蓟州区渔阳镇光明路44号文昌街派出所(不用进院内,瑞鑫轩东北菜旁边就是了) 办理时间:周一至周日8:30~16:30 办理费用&…...
浙江网站建设报价/成都seo技术
摘要:创建并设置一个WebViewClient子类,回调对应的方法改变网页内容的呈现方式,比如:网页加载错误回调onReceivedError(),提交表单错误回调onFormResubmission(),拦截URL加载回调shouldOverrideUrlLoading(…...
网站开发架构分类/培训机构
手工合并报表时,经常遇到很多问题,而且效率低下,而专业的合并报表软件只需要几步,就能快速准确汇总各子报表,生成合并的报表并动态展示。尤其是对于财务报表来说,能节省大量手工合并做账的重复做工精力。…...
做网站实例/百度指数数据分析平台
一、什么是Nginx? Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,其特点是占有内存少,并发能力强,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。…...
网站制作书籍推荐/百度指数官网登录
建筑给排水工程包括:给水、排水、热水、消火栓、自动喷淋等常用系统,其管道当中流动的是水。(其管道输送介质为水)一、给排水工程的主要功能(1)建筑给水系统的任务,就是经济合理地将水由室外给水管网输送到装置在室内的各种配水龙头、生产用水…...
dw软件做的东西怎么在网站用/营销网站建设哪家快
2019独角兽企业重金招聘Python工程师标准>>> 队列:先进先出 栈:先进后出; 实现栈:有队列1有队列2。实现原理,始终保持一个队列为空队列。取元素时,将不为空的队列所有元素减一全部放入另外一个队列。将最后…...