教你使用Visual Studio調(diào)試Linux Core Dump
Linux Core Dump不再可怕
從Visual Studio 2019 v16.8 Preview 3開(kāi)始,我們?cè)赪SL(Linux的Windows子系統(tǒng))或遠(yuǎn)程Linux系統(tǒng)上添加了對(duì)Linux Core Dump的調(diào)試支持。 此支持僅適用于非托管代碼的“本機(jī)”調(diào)試。
據(jù)我們所知的,有一些開(kāi)發(fā)團(tuán)隊(duì)主要是在Windows開(kāi)發(fā)他們的系統(tǒng),但是會(huì)同時(shí)在Windows和Linux(或者,只在Linux)上部署,然后通過(guò)CI(持續(xù)集成)系統(tǒng)來(lái)收集和Linux相關(guān)的錯(cuò)誤。這項(xiàng)新添加的特性,可以讓你的調(diào)試生活更加容易:你可以在你熟悉的環(huán)境下調(diào)試Linux應(yīng)用程序的崩潰錯(cuò)誤。有了這玩意,媽媽再也不用擔(dān)心碰到Core dump了。
使用的方法十分簡(jiǎn)單,在主菜單中選擇:[Debug>OtherDebugTargets>DebugLinuxCoreDumpwithNativeOnly…],請(qǐng)注意,這個(gè)菜單項(xiàng)只有在你安裝了[LinuxdevelopmentwithC++]工作集時(shí)才可用。如下圖所示:
在接下來(lái)的對(duì)話框中,會(huì)顯示調(diào)試會(huì)話的配置界面,如下圖所示:
你也可以在WSL或者遠(yuǎn)程Linux上調(diào)試,但是需要在目標(biāo)系統(tǒng)上安裝有GDB。
下面我們簡(jiǎn)單的來(lái)介紹一下這個(gè)對(duì)話框的各個(gè)屬性。
調(diào)試WSL(Debug on WSL)
如果這個(gè)勾選框被勾選,則Visual Studio會(huì)嘗試在默認(rèn)的WSL發(fā)行版上尋找Core Dump文件并啟動(dòng)調(diào)試會(huì)話。這個(gè)選項(xiàng)借助于我們對(duì)WSL的本機(jī)支持,而且無(wú)需安裝SSH。
調(diào)試遠(yuǎn)程Linux系統(tǒng)(Remote Debug Machine)
如果上面的[Debug on WSL]沒(méi)有被被勾選,則Visual Studio會(huì)在這個(gè)選項(xiàng)指定的遠(yuǎn)程系統(tǒng)上尋找Core Dump文件并啟動(dòng)調(diào)試會(huì)話。在下拉列表中會(huì)列出已經(jīng)建立的SSH連接。你可以在[Tools > Options > Cross Platform > Connection Manager]中添加一個(gè)新的遠(yuǎn)程連接。
Core Dump文件(Core Dump File)
這個(gè)選項(xiàng)指定一個(gè)在目標(biāo)系統(tǒng)存在的Core Dump文件路徑。
程序(Program)
這個(gè)選項(xiàng)指定產(chǎn)生Core Dump文件的可執(zhí)行文件。如果你正在WSL上調(diào)試并且你的Core Dump和可執(zhí)行文件都在Windows的文件系統(tǒng),則你可以通過(guò)將本地磁盤掛載到/mnt目錄(例如:/mnt/c/Users…)的方式來(lái)從WSL中訪問(wèn)這些文件。
源文件(Sources)
這是一個(gè)可選項(xiàng),主要用來(lái)指定在Windows上對(duì)應(yīng)的源文件所在的根目錄。如果你希望進(jìn)行源碼級(jí)調(diào)試,則這個(gè)選擇十分有用。請(qǐng)按照=格式進(jìn)行設(shè)置。另外,可以通過(guò)分隔符填入多個(gè)條目。
共享庫(kù)搜索路徑(Shared Library Search Path)
一個(gè)可選的調(diào)試符號(hào)搜索路徑(會(huì)被轉(zhuǎn)換為GDB對(duì)應(yīng)的solib-search-path屬性)。
你不需要?jiǎng)?chuàng)建一個(gè)Linux配置的CMake工程或一個(gè)基于MSBuild的Linux工程就可以使用這個(gè)功能。但是要注意的是,如果你打開(kāi)了一個(gè)Linux工程,則Visual Studio將會(huì)自動(dòng)在Program選項(xiàng)中填入對(duì)應(yīng)的信息。如果你有多個(gè)編譯目標(biāo),則Visual Studio會(huì)自動(dòng)填入它能找到的第一個(gè)目標(biāo)。
總結(jié)
我一直不太會(huì)使用GDB來(lái)調(diào)試代碼,可能是被Visual Studio養(yǎng)成了一個(gè)巨嬰吧。碰到Core dump,一般就直接啃代碼了(GDB不會(huì)啊[攤手])。有了今天的這個(gè)玩意,感覺(jué)這生活還是可以值得期待的。生產(chǎn)環(huán)境里出毛病了? 直接上Visual Studio源碼級(jí)調(diào)試:”還是原來(lái)的配方,還是同樣的味道?!?
最后
Microsoft Visual C++團(tuán)隊(duì)的博客是我非常喜歡的博客之一,里面有很多關(guān)于Visual C++的知識(shí)和最新開(kāi)發(fā)進(jìn)展。大浪淘沙,如果你對(duì)Visual C++這門古老的技術(shù)還是那么感興趣,則可以經(jīng)常去他們那(或者我這)逛逛。本文來(lái)自:《Debug Linux core dumps in Visual Studio》