码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Rider调试ASP.NET Core时报thread not gc-safe的解决方法


      新建了一个ASP.NET Core 5.0的Web API项目,当使用断点调试Host.CreateDefaultBuilder(args)时,进入该函数后查看中间变量的值,报错Evaluation is not allowed: The thread is not at a GC-safe point。在群里问了也没人回应,可能没有遇到过这个问题吧。

    一.解决问题的过程

    1.Visual Studio 2022调试

      首先想到的是可能Rider不行,换成Visual Studio 2022试试,所以就查到了文献[1],发现需要pdb文件,还需要设置符号什么的,觉得太麻烦了。

    2.Rider调试

      然后又换成了Rider,既然调试看不到中间变量的值,那就直接Console.WriteLine()出来,结果Console在当前上下文中根本就不存在,如下:

    二.最终的解决方法

    1.YouTrack上的解决方法

      继续在网上查找,发现在JetBrains的官方YouTrack上[2][3],Evgeny Terekhin在2022年5月30日给出了一个解决方法:

    SET COMPLUS_ZapDisable=1	NGen off (CLR)
    SET COMPLUS_JitMinOpts=1	Disable as much JIT optimizations as possible (CoreCLR)
    SET COMPlus_TieredCompilation=0	No tiered JIT, only do one pass (CoreCLR)
    SET COMPLUS_ReadyToRun=0	Don't do netcore's analog to NGen (CoreCLR)
    

    大概的意思是对CLR做了设置,先不管设置的什么了,抱着试试看的心态。配置launchSettings.json文件:

    "environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development",
        "COMPLUS_ZapDisable": "1",
        "COMPLUS_JitMinOpts": "1",
        "COMPlus_TieredCompilation": "0",
        "COMPLUS_ReadyToRun": "0"
    }
    

    完成的配置文件如下所示:

    2.调试ASP.NET Core

      打上断点启动调试后,神奇般的发现也可以查看中间变量了。如下:

    Rider调试源码还是比Visual Studio方便很多,不需要pdb文件,也不需要设置什么符号,只需要进入要调试的函数中打上断点,然后启动调试即可。

    参考文献:
    [1]Debugging External Sources with Visual Studio:https://devblogs.microsoft.com/visualstudio/debugging-external-sources-with-visual-studio/
    [2]Debugger: Evaluation is not allowed: The thread is not at a GC-safe point:https://youtrack.jetbrains.com/issue/RIDER-40357
    [3]When debugging, variables don't display all of their data, instead we get 'Evaluation is not allowed: The thread is not at a GC-safe point':https://youtrack.jetbrains.com/issue/RIDER-10885/When-debugging-variables-dont-display-all-of-their-data-instead-we-get-Evaluation-is-not-allowed-The-thread-is-not-at-a-GC-safe

  • 相关阅读:
    windows http-server 因为在此系统上禁止运行脚本
    QT中如何对引入的第三方库进行翻译
    XFeat:速度精度远超superpoint的轻量级图像匹配算法
    dolphinscheduler 3.0.1 数据源中心及使用
    三七互娱,oppo,快手25届暑期实习内推
    springboot2.3.7升级到springboot2.7.2
    C专家编程 第10章 再论指针 10.8 轻松一下---程序检验的限制
    【Redis笔记】主从服务器复制
    众和策略可靠吗?中国资产,一夜狂飙!
    【数据结构】优先级队列
  • 原文地址:https://www.cnblogs.com/shengshengwang/p/16573520.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号