Lnmp的运维追踪技巧总结

本文详细介绍了LNMP环境下Web请求的全过程,包括DNS解析、TCP三次握手、HTTP请求处理及前端渲染等关键环节,并针对各阶段可能出现的问题提供定位与解决方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

LNMP的运维追踪技巧总结

曾几何时我开始运维公司的LNMP网站,经过一段时间的摸爬滚打,也算是总结了不少在LNMP服务器下调试追踪各种网站错误的方法。好记性不如烂笔头,还是总结一下吧!

在开始我会梳理一下我所理解的一个web请求从发起到响应的各个阶段服务器和浏览器分别做了什么。所以的用户响应异常都是发生在这个流程中的,知道每个流程的细节可以通过不同的方法分别定位异常发生在哪个阶段,从而更准确快速的定位错误。后面就是持续更新的我在被这个网站折磨中经历的各种错误,给自己做一个记录,当然如果能帮到其他人,我也很荣幸。

一个Web请求过程中到底发生了什么?

简单的web请求

上图是一个简单的web请求全过程,嗯,画的确实有点过于简单,上图中我隐藏了很多细节,下面一一说明,可能有没涉及到的地方欢迎补充:

第一步

用户输入url如http:www.baidu.com到浏览器,浏览器如chrom需要将其解析为ip地址才知道需要到哪里去访问哪个服务器。浏览器解析DNS步骤如下:

  1. 搜索浏览器自身的dns缓存,这个缓存缓存时间短,缓存数目有限。
  2. 搜索操作系统的dns缓存
  3. 读取host文件的dns映射(一般做本地开发映射都是修改这个文件来达到拦截浏览器请求到本地服务器的目的,从而使本地可以成功映射服务器地址)
  4. 先本地网卡配置里的dns服务器发起域名解析请求,这里好像还有一套运营商的处理流程就不在展开了。
  5. 下面好像还有一些流程,由于基本不会执行到这一步,一般所以dns运营商的dns服务器都会搞定的。
  6. 解析失败,以上任何一步成功都会返回一个成功的ip地址
第二步

浏览器以一个随机的端口享这个ip地址的特定端口(默认80)发起著名的TCP3次握手。关于一个http请求是如何到达nginx服务的流程大致如下:

Created with Raphaël 2.1.2 TCP请求 进入网卡? 内核的TCP/IP协议栈? 防火墙? Nginx模块 异常 yes no yes no yes no
第三步

握手完成后的浏览器和服务器就可以愉快地发送http请求了,具体在nginx上流程如下:

Created with Raphaël 2.1.2 http请求 第二步流程 nginx进程 获取http的头部信息 匹配server_name,定位到站点的root 进入代码框架的路由 框架的路由解析器解析出php文件 php进入fastcgi进程 fastcgi进程将php填充成html文件 html文件递交给nginx并设置响应信息 response响应
第四步

浏览器根据服务器resopnse的响应头和响应体渲染出可视化页面

响应码说明
1xx信息性状态说明
2xx成功状态码
3xx重定向状态码
301永久重定向, Location响应首部的值仍为当前URL,因此为隐藏重定向
302临时重定向,显式重定向, Location响应首部的值为新的URL
304Not Modified 未修改,比如本地缓存的资源文件和服务器上比较时,发现并没有修改,服务器返回一个304状态码,告诉浏览器,你不用请求该资源,直接使用本地的资源即可
4xx客户端错误
404Not Found 请求的URL资源并不存在
5xx服务器错误
500Internal Server Error 服务器内部错误
502Bad Gateway 前面代理服务器联系不到后端的服务器时出现
504Gateway Timeout 这个是代理能联系到后端的服务器,但是后端的服务器在规定的时间内没有给代理服务器响应

上面大致梳理了下一个http请求在LNMP服务端体系下的流程。心中有个整体流程的概念才可以更好的追踪实际问题。下面就是针对上面几个基本步骤中会出现的问题的定位和追踪。

第一步和第二步出现问题,可以通过「端口可用性探测」来定位。


  1. ping www.baidu.com 检测域名解析器是否异常

检查域名解析是否错误
  • telnet 127.0.0.1 80 追踪端口是否异常
    检查端口是否打开,防火墙是否过滤
第三步出现的问题

这一步一般是网站出问题的主要地方,绝大部分问题都是出现在这个阶段,同样这个阶段出现的问题也是最难定位和解决的。为了更好的处理这个阶段的问题我们需要更深入地了解下一个web服务器与一个web程序直接的信息通信的模型与流程。

要说明这个问题,首先我们需要了解什么是大名顶顶的CGI协议、FASTCGI协议和PHP-FPM,以及它们之前的关系。

对于一个PHP的web程序来说,web服务器(如:nginx)要想与它通信需要通过CGI协议。当一个web请求触达web服务器时,web服务器会创建一个CGI进程,CGI进程将web的请求按照固定的格式进行解析,然后写入标准输入(STDIN)和环境变量中,然后PHP启动的CGI解析器会从标准输入(STDIN)和环境变量中读取http请求的数据,所以$_SERVER才会有数据,然后做出相应的逻辑处理,然后将处理结果放入标准输出(STDOUT),CGI进程从STDOUT中读取响应数据然后传输给浏览器,这样服务端就完成了一次http请求。

上面是CGI的实现流程,但是使用CGI协议的服务器在用户每次访问服务器的时候都需要fork/销毁CGI进程,必然照成多余的系统开销,所以FASTCGI就是为了解决这个问题的。

FastCGI会创建一个常驻的master进程和多个worker进程,master进程负责管理和为worker进程反派任务,worker进程负责内部嵌入了CGI解析器用于解释php代码。

PHP-FPM是一个FastCGI进程管理器,在LNMP体系中就是由它来实现FastCGI协议的。同样,它也会创建一个常驻的master进程和多个worker进程,master进程负责监听端口和接收来自nginx的请求,指派任务给worker进程。worker进程的负责解释php代码。PHP-FPM可以通过配置预先启动一定数量的worker进程,这样当http请求触达时就可以更快速的响应。

nginx与PHP-FPM之间的通信一般通过其ngx_http_fastcgi_module模块来实现。其中fastcgi_pass用于设置fastcgi服务器的IP地址;fastcgi_param设置传入fastcgi服务器的参数。这个模块出现的配置问题一般集中在这一块。

相对于并发状态下出现的问题,一般也都集中在fastcgi服务器上,具体表现为fastcgi服务器为了应对大量的http请求必须不停的fork新的worker进程,这时就需要考虑服务器可支持的最大链接数和最大打开文件数(可通过ulimit -n查看)以及php-fpm配置里的最低开启worker数和最高开启worker数的限制。高性能服务器可以在这个方向上调优。这也是我目前还在探索的地方,以后肯定也会写一个总结。

第四步出现的问题

这一步一般很少出现问题,出现问题也很容易定位,多是前端渲染问题,我也不是很懂。


未完分割线,后面我会总结一些各个阶段可能发生的错误,这些错误在客户端的表现,如何定位,以及如何解决。

参考链接

https://blog.youkuaiyun.com/ApeLife/article/details/54558112
https://blog.youkuaiyun.com/u014600626/article/details/78720763
https://blog.cuiyongjian.com/fe/tencent-cgi/
https://zhuanlan.zhihu.com/p/20694204
https://stackoverflow.com/questions/2089271/what-is-common-gateway-interface-cgi
https://paper.seebug.org/289/
https://blog.youkuaiyun.com/shreck66/article/details/50355729
http://www.phppan.com/2011/05/php-cgi/
https://github.com/pangudashu/php7-internal/blob/master/1/fpm.md
https://github.com/YuanLianDu/YLD-with-Php/blob/master/articles/php/php-fpm.md
http://blog.51cto.com/13581826/2093473
http://haiyangxu.github.io/posts/2014/2014-05-11-How_web_works_HTTP_and_CGI.html
https://www.cnblogs.com/xueweihan/p/5319893.html
https://www.zybuluo.com/phper/note/50231
https://www.awaimai.com/371.html
http://tiankonguse.com/blog/?p=896
https://www.digitalocean.com/community/tutorials/understanding-and-implementing-fastcgi-proxying-in-nginx
http://www.whizkidtech.redprince.net/cgi-bin/tutorial
https://fastcgi-archives.github.io/FastCGI_FAQ.html
https://fastcgi-archives.github.io/FastCGI_FAQ.html
http://php.net/manual/zh/reserved.variables.server.php
http://www.php-internals.com/book/?p=chapt02/02-02-03-fastcgi
https://www.yanxurui.cc/posts/server/2017-01-04-write-a-cgi-program-in-c-language/

<think>嗯,用户问的是AD软件中换层的快捷键。首先,我需要确定AD指的是哪个软件。通常,AD可能指Altium Designer,这是一款常用的电子设计自动化软件,用于电路板设计。所以用户可能是在使用Altium Designer时想要快速切换层,提高工作效率。 接下来,我需要回忆或查找Altium Designer中关于层切换的快捷键。根据之前的知识,Altium Designer中确实有一些快捷键用于切换不同的层。比如,小键盘的数字键可能对应不同的层,例如1是Top Layer,2是Mid Layer 1,依此类推。不过,不同版本可能会有些差异,所以需要确认这一点是否正确。 另外,用户可能还不太清楚如何自定义这些快捷键,或者是否有其他方式快速换层。比如,使用快捷键L调出层设置面板,或者通过Preferences设置自定义快捷键。这可能是用户潜在的需求,想要更灵活地调整快捷键以适应自己的习惯。 还要考虑用户可能的操作环境,比如是否在使用英文版软件,或者是否有安装不同版本的Altium Designer,因为不同版本快捷键可能不同。此外,用户可能对层的概念不太熟悉,比如信号层、电源层、丝印层等,是否需要简要解释这些层的用途,以帮助用户更好地理解换层的意义。 另外,是否有其他相关功能,比如切换层的同时切换走线层,或者如何在多层板中快速跳转,这些也可能是用户需要的信息。比如在布线时按数字键切换层并自动添加过孔,这样的操作是否可行,需要确认正确性。 总结一下,回答需要包括: 1. 常用默认快捷键,如小键盘数字键对应各层。 2. 如何通过快捷键L打开层设置面板。 3. 自定义快捷键的方法。 4. 可能需要注意的版本差异或操作细节。 5. 简要说明层的类型和用途,帮助用户理解为何需要换层。 需要确保信息准确,避免错误,比如Altium Designer是否真的使用小键盘数字键作为默认切换层的快捷键。可能需要查阅官方文档或可靠来源确认。此外,提醒用户如果快捷键不起作用,可能需要检查键盘设置或软件版本,确保兼容性。 最后,组织回答时要结构清晰,分点说明,便于用户理解。如果有不确定的地方,建议用户参考软件帮助文档或官方资源,以确保信息的正确性。</think>在 Altium Designer(AD)中,**换层快捷键**是提高 PCB 设计效率的重要工具。以下是常用操作说明: --- ### 一、默认快捷键 1. **小键盘数字键** - 按下数字键 **1~6** 可快速切换至对应信号层(例如:1=Top Layer,2=Mid Layer 1,依此类推)。 - **+/- 键**:切换至下一层/上一层(需开启小键盘的 Num Lock)。 2. **信号层与平面层切换** - **Shift+Ctrl+鼠标滚轮**:按住后滚动滚轮可快速切换层(需按住快捷键)。 3. **特殊层快捷键** - **L**:打开层设置面板(快速启用/禁用层显示)。 - **Ctrl+Shift+G**:切换到丝印层(Top Overlay)。 - **Ctrl+Shift+M**:切换到阻焊层(Top Solder Mask)。 --- ### 二、自定义快捷键 1. 通过 **Preferences > PCB Editor > Shortcuts** 修改快捷键。 2. 搜索功能关键词(如 `Layer Next`、`Layer Previous`)绑定自定义按键。 --- ### 三、实用技巧 1. **布线时自动换层**: 布线过程中按下对应层数字键,软件会自动添加过孔并切换至目标层。 2. **层高亮显示**: 按 **Shift+S** 进入单层模式,按层数字键可快速高亮特定层。 --- ### 四、注意事项 - 不同版本快捷键可能略有差异,建议通过 **Help > Shortcuts** 确认当前版本设置。 - 若快捷键失效,检查键盘输入法或软件冲突。 如果需要更详细的层管理(如创建/删除层),可通过 **Design > Layer Stack Manager** 操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值