一、http 协议的各个版本和区别?
二、响应码200,但是仍无法访问,原因是什么?
三、说明各种响应码分类,499的原因,502和504的区别
信息响应 (100–199) 成功响应 (200–299) 重定向消息 (300–399) 客户端错误响应 (400–499) 服务端错误响应 (500–599)
#499 通常表示客户端主动关闭了与服务器的连接,而服务器尚未完成对请求的处理。
四、比较nginx 和 apache 的特性
性能和资源消耗:Nginx是一个轻量级的Web服务器,采用C语言编写,相同的Web服务下,Nginx会占用更少的内存及资源。 Apache则相对较重,占用资源较多,尤其在处理大量并发请求时,其进程模型可能导致较高的资源消耗。 并发处理能力:Nginx以epoll和kqueue作为开发模型,处理请求是异步非阻塞的,这使得其负载能力远高于Apache,特别在高并发场景下,Nginx能保持低资源消耗和高性能。 Apache使用的是阻塞型的处理方式,当PHP处理慢或者前端压力大时,容易出现进程数激增,甚至拒绝服务的现象。 静态文件处理:Nginx在静态文件处理方面表现优秀,其静态处理性能比Apache高三倍以上,非常适合用于前端开发中静态资源的服务。 Apache虽然也能处理静态文件,但在性能方面不如Nginx。 配置简洁性:Nginx的配置文件相对简洁,正则配置使得许多任务变得简单,且配置错误可以通过-t命令快速检测出来。 Apache的配置相对复杂,且在重启时才发现配置错误可能会带来不便。 模块化和扩展性:Nginx的设计高度模块化,编写模块相对简单,这使得其易于扩展和定制。 Apache虽然也支持模块化,但其历史更为悠久,模块众多,有时可能导致复杂性增加。 动态请求处理与反向代理:Apache在处理动态请求方面具有优势,尤其是对PHP的支持较为简单。 Nginx则更适合作为反向代理服务器,可以轻松地与后端服务器(如Apache)集成,以提供负载均衡和高效的请求处理。
五、nginx 的功能
web服务器、正向代理、反向代理、负载均衡、文件服务器
六、常见的nginx 性能优化方法
七、location的优先级
Location优先级:= > ~ > ~* > ~*\.(后缀)$ > \
精确匹配、区分大小写、不区分大小写、、文件名匹配、URI匹配
location = /index.html {default_type text/html;return 200 "location = /index.html";}location /index.html {default_type text/html;return 200 "location /index.html";}location ~ /index.html {default_type text/html;return 200 "location ~ /index.html";}location ~* /index.html {default_type text/html;return 200 "location ~* /index.html";}location ~* \.(html|gif|jpg|jpeg|bmp|png|tiff|tif|ico|wmf|js|css|avi)$ {default_type text/html;return 200 "location ~* \.(html|gif|jpg|jpeg|bmp|png|tiff|tif|ico|wmf|js|css|avi)";}
八、rewrite 中 redirect,permanent, break和last区别
九、如何获取客户端真实IP
十、nginx的常见模块
核心基础类 ngx_http_core_module 功能:Nginx 处理 HTTP 请求的基础模块,定义了服务器(server)、位置(location)等核心配置结构,实现虚拟主机配置、请求处理和 URL 匹配等基础功能。 应用场景:构建 Nginx 基础配置,支持多站点部署和不同路径的请求处理。
ngx_http_log_module 功能:负责记录 Nginx 服务器的访问日志和错误日志,可自定义日志格式和存储位置。 应用场景:用于服务器性能分析、用户行为跟踪以及故障排查。
访问控制类 ngx_http_access_module 功能:基于 IP 地址或 IP 段控制客户端对服务器资源的访问权限,可设置允许或拒绝规则。 应用场景:限制特定 IP 访问敏感页面,如管理后台、内部接口等。 ngx_http_auth_basic_module 功能:实现基本的 HTTP 身份验证,要求客户端提供用户名和密码才能访问受保护的资源。 应用场景:对特定资源设置简单的访问权限,如测试环境页面、私密文档等。
性能优化类 ngx_http_gzip_module 功能:对服务器响应内容进行压缩,减少数据传输量,加快页面加载速度,提升用户体验。 应用场景:适用于传输文本类资源,如 HTML、CSS、JavaScript 文件等。 ngx_http_headers_module 功能:允许在 HTTP 响应头中添加、修改或删除自定义字段,可用于设置缓存策略、跨域访问等。 应用场景:设置 Cache - Control、Expires 等缓存头,或添加 Access - Control - Allow - Origin 实现跨域资源共享。
反向代理与负载均衡类 ngx_http_proxy_module 功能:实现反向代理功能,将客户端请求转发到后端服务器,并处理后端服务器的响应返回给客户端。 应用场景:隐藏后端服务器信息,保护服务器安全,同时实现多服务器之间的请求分发。 ngx_http_upstream_module 功能:配置后端服务器组,支持多种负载均衡算法(轮询、加权轮询、IP 哈希、最少连接等),将请求均匀分配到多个后端服务器。 应用场景:应对高并发请求,提高系统的可用性和性能,避免单台服务器负载过高。
缓存处理类 ngx_http_fastcgi_cache_module 功能:针对 FastCGI 应用程序(如 PHP)的响应进行缓存,减少重复计算,提高动态页面的响应速度。 应用场景:用于缓存动态生成的页面,如博客文章列表、商品展示页面等。 ngx_http_memcached_module 功能:使 Nginx 能够直接与 Memcached 缓存服务器交互,将经常访问的数据缓存到 Memcached 中,减轻后端服务器压力。 应用场景:缓存数据库查询结果、热门文章内容等。
安全防护类 ngx_http_ssl_module 功能:支持 HTTPS 协议,通过 SSL/TLS 加密数据传输,保障数据在传输过程中的安全性和完整性。 应用场景:保护用户敏感信息,如登录表单、支付信息等的传输安全。 ngx_http_limit_req_module 功能:限制客户端请求速率,防止恶意用户进行暴力请求或 DDoS 攻击,保护服务器资源。 应用场景:对 API 接口、登录页面等进行请求速率限制。
十一、nginx的反向代理的调度算法
轮询
原理:按顺序依次将请求分配给后端服务器列表中的服务器,循环往复。默认认为所有后端服务器处理能力相同,请求均匀分配。
适用场景:后端服务器硬件配置、性能相近的场景。
加权轮询
原理:为每个后端服务器设置一个权重值,根据权重比例分配请求。权重高的服务器会分配到更多请求,能更好地适配不同性能的服务器。
适用场景:后端服务器硬件性能有差异,如部分服务器 CPU、内存配置更高时。
IP 哈希
原理:根据客户端的 IP 地址进行哈希计算,将计算结果映射到后端服务器列表中,使相同 IP 地址的客户端请求总是被分配到同一台服务器。
适用场景:需要保持会话一致性的场景,如购物车、用户登录状态等。
最少连接
原理:将请求分配给当前连接数最少的后端服务器,使各服务器的连接负载相对均衡,充分利用服务器资源。
适用场景:后端服务器性能差异较大,或处理请求的时间长短不一的情况。
加权最少连接
原理:在最少连接算法基础上,为每个后端服务器增加权重。结合服务器性能和当前连接数来分配请求,优先将请求分配给性能好且连接数少的服务器。
适用场景:与最少连接类似,但服务器性能差异更明显时使用。
扩展算法
通用哈希
原理:可以基于任意自定义的 key(如 URL、请求参数等)进行哈希计算,根据计算结果选择后端服务器。
适用场景:有特定业务需求,需要根据请求的某些特征来固定分配到某台服务器的场景。
随机
原理:随机选择一台后端服务器来处理请求。
适用场景:对请求分配没有特殊要求,且后端服务器性能较为均衡的场景。
随机加权
原理:在随机算法基础上引入权重概念,服务器被选中的概率与其权重成正比。
适用场景:后端服务器性能有差异,又希望在随机分配过程中考虑服务器性能因素的场景。
十二、比较nginx,haprorxy和LVS的区别
十三、http的常见的响应码
十四、访问web页面时出现502和504错误,请简述—下排查思路
十五、有同事反应网站访问速度很慢,有时候会出现打不开网站的情况,刷新等待好长时间后又正常打开,请分析并说一说故障排查思路?
十六、上家公司的服务各做了哪些优化,NGINX做了哪些优化