断点后面的U-SQL代码未命中

问题描述 投票:1回答:3

我只是在学习Azure数据湖分析和U-SQL。我有一个简单的脚本运行并产生预期的输出。但是,当我在helper方法后面的代码中设置断点时,它永远不会被命中,因为没有加载任何符号。我查看了所有可用的Microsoft教程,没有人建议我必须做任何事情来启用调试,它应该在我运行时工作。

  • 我在Local上运行。
  • 我正在使用F5在调试模式下运行。
  • 脚本成功完成。
  • 输出确认执行了辅助方法

U型SQL

@searchlog = 
EXTRACT UserId          int, 
        Start           DateTime, 
        Region          string, 
        Query           string, 
        Duration        int, 
        Urls            string, 
        ClickedUrls     string
FROM "/SearchLog.tsv"
USING Extractors.Tsv();

@searchlog = SELECT
            UserId,
            DataLake.Helper.Test() AS Test,
            Start, 
            Region, 
            Query, 
            Duration, 
            Urls, 
            ClickedUrls
    FROM @searchlog;


OUTPUT @searchlog 
TO "/SearchLog_output.tsv"
USING Outputters.Tsv();

代码背后

namespace DataLake
{
public class Helper
{
    public static string Test()
    {
        Console.WriteLine("Stop");
        return "Test";
    }
}
}

输出窗口

'DebugHost.exe' (CLR v4.0.30319: DefaultDomain): Loaded.
'C:\Windows\Microsoft.Net\assembly\GAC_64\mscorlib\v4.0_4.0.0.0__b77a5c561
934e089\mscorlib.dll'. Symbols loaded.
'DebugHost.exe' (CLR v4.0.30319: DefaultDomain): Loaded 
'C:\Users\ksmith\Documents\Visual Studio 
2017\Projects\USQLApplication1\DataLake\bin\LocalDebug\DebugHost.exe'. 
Symbols loaded.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Users\ksmith\Documents\Visual Studio 
2017\Projects\USQLApplication1\DataLake\bin\LocalDebug\Microsoft.Cosmos
.ScopeStudio.BusinessObjects.Debugger.dll'. Cannot find or open the PDB 
file.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Users\ksmith\Documents\Visual Studio 
2017\Projects\USQLApplication1\DataLake\bin\LocalDebug\Microsoft.Cosmos
.ScopeStudio.BusinessObjects.Common.dll'. Cannot find or open the PDB file.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Users\ksmith\Documents\Visual Studio 
2017\Projects\USQLApplication1\DataLake\bin\LocalDebug\Microsoft.Analytics
.LocalRun.dll'. Cannot find or open the PDB file.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Windows\Microsoft.Net\assembly\GAC_MSIL\System\v4.0_4.0.0.0__b77a5c56
1934e089\System.dll'. Symbols loaded.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Users\ksmith\Documents\Visual Studio 
2017\Projects\USQLApplication1\DataLake\bin\LocalDebug\Microsoft.Cosmos.
ClientTools.Shared.dll'. Cannot find or open the PDB file.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Windows\Microsoft.Net\assembly\GAC_MSIL\System.Core\v4.0_4.0.0.0__
b77a5c561934e089\System.Core.dll'. Symbols loaded.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Windows\Microsoft.Net\assembly\GAC_MSIL\System.Xml\v4.0_4.0.0.0__b
77a5c561934e089\System.Xml.dll'. Symbols loaded.
'DebugHost.exe' (CLR v4.0.30319: DebugHost.exe): Loaded 
'C:\Users\ksmith\Documents\Visual Studio 
2017\Projects\USQLApplication1\DataLake\bin\LocalDebug\ScopeRuntime.exe'. 
Cannot find or open the PDB file.
The program '[28036] DebugHost.exe' has exited with code 0 (0x0).

任何人都可以解释为什么断点没有被击中?

添加Debugger.Launch();导致出现Choose Just-In-Time Debugger窗口。如果我选择其中一个选项,那么获得一个visual studio的实例是破解点背后的代码被击中。 VS实例称为LocalVertexHost

JIT Debugger

谢谢

visual-studio-2017 azure-data-lake u-sql
3个回答
0
投票

DataLake Analytics的扩展对于visual studio来说是一个问题。我已经并且仍然有这个问题。按照以下步骤进行一些运行可以正常运行,然后再重复一遍:

  1. 清理您拥有的所有项目:ADLA和ADLA类库;
  2. 确保两个项目上的调试文件夹都为空;
  3. 使用后面的代码重建并注册到您当地的ADLA类库;
  4. 重建您尝试调试的脚本;
  5. 使ADLA项目成为您的启动项目;
  6. 将脚本提交到本地ADLA(确保在调试中包含所有需要的文件,并将脚本指定为启动脚本);
  7. 提交成功后,将brak point放入后面的代码中;
  8. 开始调试;

如果尚未命中断点,则尝试从本地U-SQL临时文件夹中删除所有内容,然后再次重复所有步骤。


0
投票

当我单击Visual Studio中的“提交”按钮而不是点击F5或单击“启动”(使用调试)时,就会发生这种情况。以为我应该分享即使你提到已经用f5运行,因为这是我能找到的这个问题的唯一提及。也许这会对其他人有所帮助。

我认为单击提交会在没有附加调试器的单独进程中运行usql脚本。


-1
投票

转到Visual Studio中的“调试”选项并确保以下内容:

  • 取消选中“启用我的代码”
  • 检查“抑制模块负载的JIT优化”
© www.soinside.com 2019 - 2024. All rights reserved.