一路踩坑,被迫聊聊 C# 代码调试技巧和远程调试
一:背景
1. 講故事
每次項(xiàng)目預(yù)交付的時(shí)候,總會(huì)遇到各種奇葩的坑,我覺(jué)得有必要梳理一下以及如何快速解決的,讓后來(lái)人避避坑,這篇就聊聊自己的所聞所遇:
我去,本地環(huán)境代碼跑的哧溜,上了測(cè)試環(huán)境出問(wèn)題
我去, 第三方提供的 dll 跑出 bug 了
二:兩個(gè)大坑的解決方案
1. 本地環(huán)境沒(méi)問(wèn)題,上了測(cè)試出問(wèn)題
相信很多朋友都有我這樣類(lèi)似的遭遇,明明程序代碼,配置文件都一樣,挪了一個(gè)窩就出問(wèn)題,你說(shuō)氣人不,既然問(wèn)題出了那怎么快速解決呢?對(duì),就是用調(diào)試,但程序部署在 centos 上,送一個(gè) visualstudio 上去也不現(xiàn)實(shí),在這種限制級(jí)條件下還想調(diào)試怎么辦呢?不錯(cuò),可以上遠(yuǎn)程調(diào)試,然后就很快查到了測(cè)試機(jī)器中的某一個(gè)環(huán)境變量搞錯(cuò)了,事情的來(lái)龍去脈搞清楚了,接下來(lái)就看看怎么實(shí)現(xiàn) local 到 centos 的 遠(yuǎn)程調(diào)試。
1) 測(cè)試代碼
為了方便演示,我就在 Action 中讀取 strategy 環(huán)境變量。
public?class?HomeController?:?Controller{public?IActionResult?Index(){ViewBag.strategy?=?Environment.GetEnvironmentVariable("strategy");return?View();}}2) 安裝 SSH
要遠(yuǎn)程調(diào)試,需要在遠(yuǎn)端機(jī)安裝 SSH,因?yàn)楹竺娓郊舆M(jìn)程調(diào)試 就要借助 SSH 打通。
yum?install?openssh-server?unzip?curl安裝完成后,就能看到 22 端口已啟動(dòng)
[root@localhost?data]#?netstat?-tlnp Active?Internet?connections?(only?servers) Proto?Recv-Q?Send-Q?Local?Address???????????Foreign?Address?????????State???????PID/Program?name???? tcp????????0??????0?0.0.0.0:22??????????????0.0.0.0:*???????????????LISTEN??????1126/sshd??????????? tcp????????0??????0?127.0.0.1:631???????????0.0.0.0:*???????????????LISTEN??????3037/cupsd?????????? tcp????????0??????0?127.0.0.1:25????????????0.0.0.0:*???????????????LISTEN??????1739/master???? tcp6???????0??????0?:::22???????????????????:::*????????????????????LISTEN??????1126/sshd??????????? tcp6???????0??????0?::1:631?????????????????:::*????????????????????LISTEN??????3037/cupsd?????????? tcp6???????0??????0?::1:25??????????????????:::*????????????????????LISTEN??????1739/master??3) 程序的發(fā)布配置
發(fā)布配置上,第一個(gè)要確保是 debug 版本,第二個(gè)要確保是 可移植模式 (Portable), 如下圖:
4) 使用附加進(jìn)程調(diào)試
在菜單欄依次選擇:Debug -> ?Attach To Process,然后填寫(xiě) ssh 需要的各種信息,如下圖:
點(diǎn)擊 Connect 后,就能看到遠(yuǎn)端機(jī)器的 dotnet程序 進(jìn)程號(hào),選擇該進(jìn)程進(jìn)行附加,在 Select Code Type 中選擇 Nanaged (.NET Core for Unix)即可,如下圖:
5) 順利調(diào)試
在 瀏覽器中鍵入:http://192.168.142.130/Home/Index ,可以看到我的 C# 代碼被命中,也順利的拿到了遠(yuǎn)端機(jī)器的 環(huán)境變量,問(wèn)題也就迎刃而解。
2. 第三方 dll 出 bug 了
調(diào)試程序除了使用 F9 進(jìn)行調(diào)試,相信也有不少朋友知道斷點(diǎn)是可以編輯的,比如說(shuō):設(shè)置表達(dá)式斷點(diǎn),過(guò)濾器斷點(diǎn),命中次數(shù)斷點(diǎn),動(dòng)作斷點(diǎn),下如圖:
第一個(gè)問(wèn)題就來(lái)了,這些花式斷點(diǎn),你真的會(huì)用嗎?真的會(huì)經(jīng)常用嗎?
讓我來(lái)回答的話,不到萬(wàn)不得已我是不會(huì)用的,我更愿意在代碼中加入利于調(diào)試的測(cè)試語(yǔ)句,原因有三點(diǎn):
更加靈活
這個(gè)顯而易見(jiàn),在面板中設(shè)置條件相比用純語(yǔ)句設(shè)置要麻煩得多,點(diǎn)來(lái)點(diǎn)去,而且還要條件疊加,復(fù)雜的很,我是不喜歡。
功能強(qiáng)大
編輯面板上只有簡(jiǎn)單的并且關(guān)系,而且各個(gè)條件還是同級(jí)別的,無(wú)法做到各個(gè)條件的或者關(guān)系以及層級(jí)或者遞歸的包含關(guān)系,所以。。。沒(méi)辦法。。。
更易于保存
這個(gè)就有意思了,在斷點(diǎn)上右鍵是彈出編輯面板,點(diǎn)擊左鍵是關(guān)閉斷點(diǎn),問(wèn)題就出在這里,經(jīng)常由于手賤,本想點(diǎn)右鍵結(jié)果點(diǎn)了左鍵 ????????????。。。。好不容易設(shè)置好的條件沒(méi)了。。。真的沒(méi)了????????????,從此以后,路轉(zhuǎn)黑。如下圖:
那這么說(shuō)斷點(diǎn)編輯真的沒(méi)用嗎?我覺(jué)得只有在不能修改語(yǔ)句的調(diào)試場(chǎng)景下能夠大顯身手,比如我遇到的調(diào)試廠家封裝的dll,哈哈,既然說(shuō)到了斷點(diǎn),我就用 dnspy 演示幾個(gè)斷點(diǎn)給大家復(fù)習(xí)一下吧!
1) 測(cè)試代碼
為方便演示,用 for 循環(huán)案例是最好的。
public?static?void?Main(string[]?args){var?sum?=?0;for?(int?i?=?0;?i?<?10000;?i++){sum?+=?i;}Console.WriteLine($"sum={sum}");}2) 我希望在 sum = 1035 的時(shí)候命中斷點(diǎn)
這個(gè)用條件表達(dá)式斷點(diǎn)就可以了,非常簡(jiǎn)單,如下所示:
3) 找到所有能夠被 1800 整除的數(shù),并且記錄下當(dāng)時(shí)的 i 和 sum 值
這里就可以用到 Action 斷點(diǎn)的日志記錄,在 for 循環(huán)迭代中,不需要中斷斷點(diǎn),只需記錄某一個(gè)特定狀態(tài)下當(dāng)前的 i 和 sum 的值,對(duì)調(diào)試代碼非常有幫助,如下圖:
三:總結(jié)
總的來(lái)說(shuō)這兩個(gè)經(jīng)驗(yàn)也算我一步一步踩坑過(guò)來(lái)的,如果能幫到你就更好了,本篇就聊這么多,下篇再見(jiàn)!
總結(jié)
以上是生活随笔為你收集整理的一路踩坑,被迫聊聊 C# 代码调试技巧和远程调试的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: TIOBE 11 月榜单:Python
- 下一篇: c# char unsigned_dll