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