- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
在过去的几个月里,我收到了一些来自 QA 的关于我们的一项服务挂起的报告。在使用 WinDbg 检查挂起转储时,每次我都会发现同样的事情:Loader lock critical section 已被锁定,但找不到拥有线程。由于线程消失了,我唯一能看到的痕迹是它留下的全局临界区,我看不到线程线程上运行了什么代码,甚至看不到该线程来自哪个 DLL,它甚至可能不是其中之一我们的(即第三方供应商)。
这个问题非常偶发,在过去 6 个月里只在野外自然发生过 3-4 次。所有其他时间,服务运行完美。所以这让我相信这是某种时间/竞争条件。
最近,我决定自己解决这个问题。我用 WinTask 脚本设置了一台机器,不断启动/停止上述服务。好消息是我可以在 5-6 小时内重现该问题。
现在进入下一部分:如何隔离它?
这是我到目前为止尝试过的:
使用 gflags 图像设置中的“调试器”字段来在启动时自动在 cdb 下运行该服务。到目前为止,它已经运行了两天并且从未挂起,所以我认为调试器引入了足够的时间更改以使问题不可见。
已下载 Application Verifier 并将流程配置为使用它运行。发现了一个完全不相关的错误,我们创建了 CComBSTR 临时变量,将其分配给 VARIANT 并将变体传递给函数调用,即使 CComBSTR 很早就删除了分配的字符串。不要相信这个错误是相关的,因为字符串是只读的并且它运行的线程不是正在死亡的线程。
我写这篇文章是为了防止你们想到我没有考虑的事情。
我虽然有一个 Windows 实用程序人为地给 CPU 施加负载并做了其他事情来弹出竞争条件,我认为应用程序验证器做了这样的事情,但显然它没有。有谁知道我在做什么,还是我只是在做梦?
除非周末发生什么事,否则我的下一步将是禁用所有调试器,返回库存并破解其中一个 DllMains 以记录 THREAD_ATTACH/THREAD_DETACH 事件。至少我能够拦截在创建时正在死亡的线程。这可能会有所启发。
最佳答案
我可能会尝试附加一个内核调试器,然后在 Appilcation Verifier 下运行该进程。 AV 会检查在它持有 CS 时卸载 DLL 并终止仍持有 CS 的线程。因此,这些断点应该在内核调试器中触发,然后希望您可以立即捕获它。在 KD 下运行它有望不会像用户模式调试器那样减慢速度。
关于c++ - 寻找调试棘手的 Windows 服务启动 gremlin 的想法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8867904/
我想连接到我的 gremlin 服务器,我在其中提供了具有同一主机的 gremlin-server.yaml 和 remote.yaml。我的 gremlin 在 Linux 服务器上。在发出 :re
我正在使用 Gremlin-Java 和远程模式与 JanusGraph 进行交互。我现在在边缘定义一个新属性,以便在使用特定策略时过滤它们。以下是我尝试在应用程序中运行的代码,但该策略似乎被完全忽略
使用 gremlin-javascript ,我使用以下方法连接到远程服务器: const gremlin = require('gremlin') const Graph = gremlin.str
如何使用 AWS Neptune GDB 在 gremlin 控制台中将字符串值转换为整数类型。我有字符串值的属性“age”,需要将其转换为 Integer 类型以用于查询中的数学运算。感谢所有建议。
我正在尝试比较我在 gremlin-console 中查询的响应时间(图形数据库是 janusgraph,后端数据库是 hbase)。为此,有一个“clock()”步骤,它可以多次运行查询并返回平均响
我是 Gremlin 的新手,我需要帮助来设置最佳查询以选择唯一和过滤的结果。 从一个 team 开始,我会得到每个 的 player (注意:每个玩家可以为多个团队效力)由 is_friends_w
我有一组具有相同属性“TYPE”的顶点。 如何为所有给定的顶点集更新此属性。 最佳答案 您可以遍历所有顶点并使用 sideEffect 更新它们的 type 属性。例如: g.V.sideEffect
我是 Gremlin 的新手,只是想建立一个基本的图表。我已经能够在新顶点上做一个基本的 addEdge,即 gremlin> v1 = g.addVertex() ==>v[200004] grem
假设我想从我的数据库中获取一些顶点: g.V(1, 2, 3) 然后我有另一组顶点: g.V(4, 5, 6) 想象一下,这不仅仅是 g.V() ,但是一些更复杂的遍历来获取我的顶点。但是遍历必须从V
当我查询路径时,例如: g.V(1).inE().outV().inE().outV().inE().outV().path() path()中既有顶点也有边,请问有没有办法只计算路径中的顶点数而忽略
在 Neptune 工作台上使用 python gremlin,我有两个功能: 第一个添加一个带有一组属性的Vertex,并返回遍历操作的引用 第二个增加了遍历操作。 出于某种原因,第一个函数的操作被
我想创建一个显示连接和连接强度的边缘列表。此示例图包含 4 个人以及他们参加研讨会 A 和 B 的信息,包括他们参加的天数和他们停留的小时数。我想通过研讨会节点建立联系,如果他们在同一天参加同一个研讨
我在 gremlify 上描述了这里的图表.所以我有四种类型的顶点:内容、用户、组和视频。 Content 和 Group 作为容器,User 和 Video 是叶子。此外,我在组和用户、组和内容、组
Gremlin 查询通常使用或生成列表。有时希望能够反转列表。目前 Gremlin 没有 reverse步骤,因此您不能执行以下操作: g.inject(['A','B','C','D']).reve
我有一个简单的图,其中 parent 和 child 是顶点。 parent 与他们的 child 有“isParentOf”关系。所有顶点都有一个属性:“familyName”。 我想使用 grem
我有这样的结构: 组 -> 字段 -> 值 和命令 g.V().hasLabel('groups').out('fields').out('values') 如何按字段和“组”顶点对这些值进行分组?
我很难在 gremlin 中找出以下场景的查询。这是有向图(可能是循环的)。 我想获得前 N 个有利节点,从节点“Jane”开始,这里的优先级定义为: favor(Jane->Lisa) = edge
这是一个非常简单的查询: g.V('customerId').out().path() 这个的 JSON 输出是 { "requestId":"96b26c1d-d032-2004-d36e-
有没有一种方法可以使用 Gremlin 查询仅返回图节点所有属性的子集? 我知道您可以使用转换管道连接属性值,但我更感兴趣的是获得结构化结果(例如 propertyName1 = value1、pro
我将 AWS Neptune Gremlin 与 gremlin_python 一起使用. 我在属性(property)中的日期按要求存储为日期时间 Neptune specs . 我使用 Pytho
我是一名优秀的程序员,十分优秀!