- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这是一个元问题,因为我认为我有一个适合我的解决方案,但它也有其缺点和缺点。我需要做一个相当普通的事情,在一个线程上捕获SIGSEGV
(没有专用的崩溃处理线程),转储一些调试信息并退出。
这里要了解的事实是,崩溃时,我的应用程序运行llvm-symbolizer
会花一些时间(相对而言)并导致产生结果(由于clone + execve
或超出线程的时间量),我已经看到后者在自己进行符号化时发生使用libLLVM
进行处理)。进行所有这些操作的原因是获得具有脱字符符号和行/文件信息(存储在单独的DWP文件中)的堆栈跟踪。出于明显的原因,我不希望在SIGSEGV
处理程序上发生任何事情,因为我打算在应用程序(线程组)执行后终止它,并且永远不要从信号处理程序中返回。
尽管我不了解Linux信号处理以及glibc的包装器对它们的处理能力,但我并不了解基本的陷阱,但是关于信号处理的具体细节并没有太多信息,例如同步信号处理程序是否获得任何特殊的优先级在调度方面。
集思广益,我有一些想法和缺点:
pthread_kill(<every other thread>, SIGSTOP)
-具有更多线程的笨拙功能,可与信号处理程序进行交互,这似乎可能具有意外的副作用。还需要拦截其他库中的线程创建,以跟踪线程列表,并在每次系统调用时增加抢占的机会。一旦它们停下来指向syscall exit
stub 或完全使用SIGKILL
,甚至可能更改其上下文。 pthread_cancel/pthread_testcancel
)。更安全,但需要大量维护,并且在整个代码库中,除了会产生轻微的性能开销外,还有些麻烦。全局标志还可能导致错误级联,因为该程序已经处于不可预测的状态,因此让任何其他线程在那里运行已经不是很大。 FIFO
调度策略并提高优先级,因此成为该组中唯一可运行的线程。 glibc
的典型的基于
NPTL
的Linux(4.4)发行版。
FIFO
线程一起运行的事实。但是,我可以将进程的亲和力更改为仅在与崩溃线程相同的内核上执行,这基本上将在时间表边界有效冻结所有其他线程。但是,这仍然保留了“由于阻塞IO而导致的FIFO线程屈服”的情况。
FIFO + SIGSTOP
选项是最好的选择,尽管我确实想知道是否还有其他技巧可以使线程无法使用
SIGSTOP
来安排。从文档上看,似乎不可能将线程的CPU亲和力设置为零(将其置于技术上可运行的边缘状态,除非没有可用的处理器可运行)。
最佳答案
upon crash, my application runs llvm-symbolizer
malloc
,如果这样的话,如果崩溃也发生在
malloc
内部(例如,由于其他地方的堆损坏),则肯定会死锁。
Switching to FIFO scheduling policy and raising priority therefore becoming the only runnable thread in that group.
SCHED_FIFO
线程是可运行的,它将一直运行(即不会发出任何阻塞的系统调用)。如果该线程确实发出了这样的调用(必须这样做:例如,用单独的
open
文件
.dwp
),它将阻塞并且其他线程将变为可运行状态。
关于linux - 如何确保信号处理程序永远不会屈服于同一进程组中的线程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49958057/
我有以下对象: dog = { location: { x: 52.1089, y: 16.2323 }, f: function(message) { alert
在 TSQL 中,如果我要搜索有效的 .com 电子邮件地址,我需要确保有一个 @ 符号,它以 .com 结尾,并且在 @ 前后至少有一个字符。 SELECT * FROM CUSTOMER WHER
我正在尝试准备一个信用卡交易列表,以便在 Excel 2010 中进行透视和进一步分析(满足个人需求)。问题是我的银行机构没有遵循标准的日期格式,所以有时日期会显示为 Jun. 1, 2013 , 有
看来您不能在 riak 中进行交易。如何确保数据正确? 假设我们要插入评论。在 redis 我会做 commentId=incr commentCount multi SET comment_post
对于下面给定的模式,是否可以确保至少一个属性包含一个值(即 minLength 为 1): { "$schema": "http://json-schema.org/draft-04/sche
我计划在 Haxe 的一个子集中编写 Haxe 库,这些库将编译为每种 Haxe 目标语言。有什么方法可以验证 Haxe 程序是否可以编译为所有目标语言,是否可以在不手动测试每个目标平台上的编译代码的
如果浏览器窗口未聚焦,则当前页面上的所有 webdriver 标识都失败。 如何使用 webdriver 使浏览器成为焦点? 最佳答案 ((JavascriptExecutor) webDriver)
我从这样的 HTML GET 请求中获取图像链接... www.example.com?image=www.anotherdomain.com/image.jpg if (isset($_GET['i
我有一个 eunit 测试,它生成一个唯一的节点名称并开始分发: {A,B,C} = now(), Nodename = list_to_atom(lists:flatten(io_lib:forma
我正在完成我的 iPhone 应用程序。我只是担心我们的网络服务器级别的安全性。数据通过网络服务被传送到 iPhone 应用程序。 我可以在网络服务上采取哪些安全措施,以免受到攻击? 谢谢 最佳答案
我正在编写一个应用程序,该应用程序启动一个运行简单 Web 服务器的子进程。我正在使用 NSTask 并通过管道与其进行通信,一切看起来或多或少都很好。但是,如果我的程序崩溃,子进程将保持事件状态,并
我有一些应用程序,我调用 ShowMessage('Complete!');在长时间操作结束时。 大多数时候,这效果很好,但每隔一段时间,消息对话框就会显示在主窗体后面。 有什么方法可以确保 Show
我通过将消息插入集合并让模板使用 {{#each}} 打印出集合来创建一个简单的聊天。 我不太熟悉安全性,但是有没有办法让它符合 EFF 规定? https://www.eff.org/secure-
我有一个商店,我想在其中正确管理 id。假设我有以下帖子存储: type Post = { id: number; title: string; body?: string; } type
我有一个使用 ajax post 方法和数据表的程序。经过几周的摆弄,我确定我根本不明白 javascript 是如何工作的。这是我的 JavaScript: $('#SaveTimeSheet').
我有一个系统,如果从 Azure 服务总线丢失消息将是一场灾难,也就是说,数据将永远丢失,并且没有实际方法可以在不造成重大中断的情况下修复损坏。 在这种情况下我可以完全依赖 ASB 吗? (即使它
如何确保 scalatest 测试不会并行运行?在 0.12 之前,我有一个 sbt 设置: parallelExecution in Test := false 新版本引入了一些复杂的机制。这种更简
我的端点有两个如下所示的 promise : request.post({ url: url, json: smsSTART, header
简短版本 当 ui-router 转换到新 View 时(以我不完全理解的方式使用 ngAnimate),它会添加类 ng-leave 和 ng-leave-active 到当前 View 。它还将类
目前正在努力寻找验证 2 个表的方法(有效地验证表 A 的大量行) 我有两张 table 表A ID A B C 表格匹配 ID Number A 1 A 2 A 9 B 1
我是一名优秀的程序员,十分优秀!