前端工程师生产环境 debugger 小技巧
Posted 小生方勤
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端工程师生产环境 debugger 小技巧相关的知识,希望对你有一定的参考价值。
是否携带错误提示,有则表示后端返回的;如果报错的接口刚好是以非
的状态码返回,如果此时请求了大量的接口(举个例子:进入页面调用了大量的接口,其中有一个接口返回了错误信息),那么除了逐个翻阅 network 这种低效的方式,chrome devTools 还提供了 network search 面板这种更便捷的方式,可以搜索接口详细信息(包括详细的返回信息),返回匹配结果。200
的状态返回,或者是由新的操作触发调用接口,我们很快就能查找到对应的接口,如下:如何打开 network search 面板?
在 network 面板中,按快捷键
⌘ + F
(Mac)、CTRL + F
(Windows)可呼出 network search 面板。如果确定需要你把大象装进冰箱,那把大象装进冰箱的技巧有哪些?
(Mac),CTRL + SHIFT + F
(Windows)看下图例子,我们随便找个页面根据提示搜索代码:
可以尝试使用哪些关键字进行搜索:
(1) 页面存在明确的报错信息,且已经明确该错误文案是写在前端代码中错误信息文案。提示信息在 coding 过程中一般是使用 字符串,压缩混淆过程中一般是不会进行处理的,会保留原文,当然代码打包构建过程中,对代码压缩混淆也可以选择对中文进行 unicode 转码,此时如果关键字是中文,就需要先转码再搜索了。
(2) 已知相关代码中存在的编译混淆后依然还保留的的关键代码,会向外暴露的方法名;
、b
、c
、d
替换了原有的函数方法名、变量名,编译后的代码已经不是能通过单纯的读代码码能读懂的了。但是我们通过 debug ,大概还是能看得懂。那么有没有方式使用本地的 sourceMap 调试生产环境的代码?答案当然是有的。
如何在生产环境使用本地 sourceMap 调试?第一步:打开混淆代码
第二步:右键 -> 选择【Add source map】
第三步:输入本地 sourceMap 的地址(此处需要启用一个静态资源服务,可以使用 http-server (https://www.npmjs.com/package/http-server)),完成。本地代码执行构建命令,注意需要打开 sourceMap 配置,编译产生出构建后的代码,此时构建后的结果会包含 sourceMap 文件。
关联上 sourceMap 后,我们就可以看到 sources -> page 面板上的变化了
如何在 chrome 中修改代码并调试?开发环境中,我们可以直接在 IDE 中修改代码,代码的变更就直接更新到了浏览器中了。那么生产环境,我们可以直接在 chrome 中修改代码,然后立马看代码修改后的效果吗?
当然,你想要的 chrome devTools 都有。chrome devTools 提供了 local overrides 能力。
local overrides 如何工作的?指定修改后的文件的本地保存目录,当修改完代码保存的时候,就会将修改后的文件保存到你指定的目录目录下,当再次加载页面的时候,对应的文件不再读取网络上的文件,而是读取存储在本地修改过的文件。
local overrides 如何使用?首先,打开 sources 下的 overrides 面板;
然后,点击【select folder overrides】选择修改后的文件存储地址;
再然后,点击顶部的授权,确认同意;
最后,我们就可以打开文件修改,修改完成后保存,重新刷新页面后,修改后的代码就被执行到了。
⚠️注意,原js文件直接 format 是无法修改的;在代码 format 之前先添加无效代码进行代码变更进行保存,然后再 format 就可以修改;
总结chrome 调试技巧远远当然不只这些,以上只是生产环境 debug 的小技巧,祝愿大家用不到,最好的 bug 处理方式当然是事前,在上线前得到就解决;如果真的发生问题,如果做好监控和日志,在问题发生的第一时间发现并解决。
参考文献https://developer.chrome.com/docs/devtools
企业生产环境生成MGR复制组名UUID的小技巧
UUID:通用唯一识别码(Universally Unique Identifier)的缩写。在MGR复制中,复制组的名称就是使用UUID,对于刚接触Linux的小伙伴来说,这个UUID该怎么生成可能会一头雾水。loose-group_replication_group_name = " e1329d71-804a-495c-ad3e-b33ae48620a8"
有一个简单的命令可以生成UUID——uuidgen
[[email protected] ~]# uuidgen
e1329d71-804a-495c-ad3e-b33ae48620a8
给自己做个小记录
以上是关于前端工程师生产环境 debugger 小技巧的主要内容,如果未能解决你的问题,请参考以下文章