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