- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个名为批处理启动器的 bash 脚本在工作。它负责启动和报告各个批处理的状态。批处理的启动是这样完成的:
env $BENV setsid $BATCH $OPT >> $FILE 2>&1
几个月前,我遇到了一个问题,其中一个带有 fork 子项的批处理在 PGID 上发送了一个终止信号,最终终止了该批处理和批处理启动器,这是一个很大的禁忌。我对这个问题的解决方案是添加 setsid
部分(因为 bash 不允许 setpgrp
),这会创建一个新 session 并因此创建一个新的 PGID。
现在我有另一个问题。同样讨厌的批处理有 fork 的 child ,除了 child 在他们的工作完成之前不会写任何日志。在调查这个问题之后,我找到了原因 here - setsid
产生了一个没有 TTY 的进程,在这种情况下,子进程的任何输出都不会在每个换行符上自动刷新,而是在最后刷新一次就在流关闭之前。这意味着如果一个 child 死于错误,缓冲区中的日志将永远消失,证明任何调试都是不可能的。
有没有办法告诉 setsid
自动刷新 STDOUT/STDERR 输出流?谷歌搜索没有得到任何结果,此时我唯一的解决方案是用支持 setpgrp
的语言(如 PERL 或 C)重写批处理启动器,这需要 QA 进行大量测试。
编辑:
小提示,问题可以通过以下方式解决:
env $BENV 脚本 -qec "$BATCH $OPT"-af $FILE
这需要 util-linux
早于 2010 来支持 -e
返回代码处理的标志(不幸的是,我使用 2005 年的 RHEL5 时情况并非如此,请参阅 commit了解详情)。
最佳答案
添加 stdbuf -o0
(无缓冲,或 stdbuf -oL
行缓冲)
env $BENV setsid stdbuf -o0 $BATCH $OPT >> $FILE 2>&1
应该可以解决问题(只要通过 libc 的 stdio 和 libc 动态链接的 $BATCH 缓冲区(默认))。
编辑:
这是一个快速的'n'dirty stdbuf -o0
模拟:
#!/bin/sh -e
trap 'rm -rf "$tmpd"' EXIT HUP INT QUIT TERM
tmpd=$(mktemp -d)
cat > "$tmpd/unbuf.c" <<EOF
#include <stdio.h>
__attribute__((constructor))
static void unbuffer(void){ setvbuf(stdout, 0, _IONBF, 0); }
EOF
gcc "$tmpd/unbuf.c" -o "$tmpd/unbuf.so" -fpic -shared
LD_PRELOAD="$tmpd/unbuf.so" "$@"
关于linux - 是否可以在没有 TTY 的情况下自动刷新 STDOUT/STDERR?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41900132/
我正在阅读The TTY demystified ,试图对 tty、pty 有一些了解。 读完前半部分。当我在 xterm 或 ssh 中输入一些命令时,我无法全面了解整个事情是如何工作的。 下图是我
假设我登录到终端 tty1,现在我想从 tty1 运行一个脚本,它会自动让我登录到 tty2、tty3、tty4。当然,我不想到处输入密码和用户名,因为我已经在 tty1 上进行了身份验证。 问题:如
为什么在我将 CentOS 作为 Docker 容器启动后,当我运行 tty 时,我得到: # tty not a tty 不是 tty 的原因是什么? 最佳答案 docker run 不会模拟 TT
我正在尝试通过 php 安装 composer,如他们的网站所述。 php -r "readfile('https://getcomposer.org/installer');" | php 但它显示
我正在运行一个 docker 容器并正在检查它。我发现 "Config": { "Hostname": "amb1.service.consul", "Domainname": "", "User":
我想用 2 个 xterm 窗口调试控制台 linux 应用程序:一个窗口用于 gdb,另一个用于应用程序(例如 mc)。 我现在要做的是在第二个 xterm 窗口中运行“tty && sleep 1
docker exec -it 命令返回以下错误“无法在非 tty 输入上启用 tty 模式” level="fatal" msg="cannot enable tty mode on non tty
这是命令的输出: Step 5/7 : RUN ./vendor/bin/laravel new --force testapp ---> Running in dc92e378b12a Craft
请帮助 MySQL Git Bash winpty mysqldump。 “winpty mysqldump”在 Git Bash 中不工作。这里是错误的详细信息: Git 狂欢 $ winpty m
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 7 年前。 Improve this ques
我一直在试图弄清楚 TTY 驱动程序是如何工作的(充分理解每个内核的实现可能不同),并且偶然发现了一篇不错的文章:The TTY demystified 但是我注意到它声称 xterm 没有 stdi
我正在使用 fork() 和 execvp() 来生成一个进程,该进程必须相信它已连接到交互式终端才能正常运行。 生成后,我想捕获进程的所有输出,并能够将输入发送到进程。 我怀疑 psuedo-tty
我在 ReactJs + 样式组件中遇到这个错误。我该如何解决? Compiled with problems: ERROR in ./node_modules/colorette/index.js
我在 ReactJs + 样式组件中遇到这个错误。我该如何解决? Compiled with problems: ERROR in ./node_modules/colorette/index.js
你好,这是我的脚本: import sys import LED import os import subprocess if __name__ == '__main__': LED_BLUE
我有几个问题。一,如何确定程序使用的 TTY,然后将其作为参数传递给另一个程序? 此外,我正在使用 writevt 程序,并将字符串发送到 TTY 设备。它工作正常,但不使用我发送它的回车符。所以,我
我想从内核空间写入 tty,并且只能访问该特定 tty 的主要和次要设备号。 我通过系统调用进入内核,该系统调用工作正常,并且能够通过使用写入当前 tty my_tty = current->sign
我最近注意到我的系统(运行在 AT91SAM9G15 上)有一个非常奇怪的行为:尽管我一直在读取串行端口,但 TTY 驱动程序有时需要 1.2 秒才能从输入队列传送数据。事情是:我没有丢失任何数据,只
我在没有屏幕的硬件上运行 linux,并将所有数据转储到串口。我正在通过 hyperterm 或 teraterm 等应用程序阅读 linux 序列。我得到了正确格式化的串行输出。但是,如果我将该输出
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我是一名优秀的程序员,十分优秀!