- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在调试一个守护进程,我正在尝试使用 print
语句将信息输出到终端。我的代码的要点是:
#!/usr/bin/env perl
use strict;
use warnings;
use Readonly;
Readonly my $TIMEOUT => ...;
...
while (1) {
print "DEBUG INFO";
...
sleep $TIMEOUT;
}
但是,它没有输出到我的终端。这是为什么?
最佳答案
使用$| = 1
或在打印中添加换行符 "\n"
。
这不打印到终端的原因是因为 perl 正在缓冲输出以提高效率。一旦打印缓冲区被填满,它将被刷新并且输出将出现在您的终端中。您可能需要强制刷新缓冲区,因为根据 $TIMEOUT
的长度,您可能需要等待相当长的时间才能输出!
刷新缓冲区有两种主要方法:
1) 当您打印到您的终端时,您的文件句柄很可能是 STDOUT
。默认情况下,附加到终端的任何文件句柄都处于行缓冲模式,我们可以刷新缓冲区并通过向您的 print
语句添加换行符来强制输出:
while (1) {
print "DEBUG INFO\n";
...
sleep $TIMEOUT;
}
2) 第二种方法是使用 $|
当设置为非零时,使当前文件句柄(STDOUT
默认情况下或最后一个被select
ed)热并强制刷新缓冲区立即。因此,下面也会强制打印调试信息:
$| = 1;
while (1) {
print "DEBUG INFO";
...
sleep $TIMEOUT;
}
如果使用这样的语法令人困惑,那么您可能需要考虑:
use IO::Handle;
STDOUT->autoflush(1);
while (1) {
print "DEBUG INFO";
...
sleep $TIMEOUT;
}
在许多需要立即刷新缓冲区的代码示例中,您可能会看到 $|++
用于使文件句柄变热并立即刷新缓冲区,而 -- $|
使文件句柄变冷并关闭自动刷新。有关详细信息,请参阅这两个答案:
如果您有兴趣了解有关 perl 缓冲区的更多信息,那么我建议您阅读 Suffering from Buffering ,它深入了解了为什么我们有缓冲,并解释了如何打开和关闭它。
关于perl - 为什么我的 perl 守护进程不打印?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32676834/
一 点睛 线程可以设置为守护线程,ThreadGroup 也可以设置为守护 ThreadGroup,但是若将一个 ThreadGroup 设置为 deamon,也并不会影响线程的 daemon 属性,
我有一个 python 脚本需要在启动时作为守护进程运行。进程从 tty(和 pdb)分离,但代码不运行。 我已经将它缩小到一个最小的例子 import daemon from time import
reactjs isMounted API 的文档提到: You can use this method to guard asynchronous calls to setState() or fo
我正在开发一个需要嵌入 HTTP 服务器的守护进程。我正在尝试使用 BaseHTTPServer 来完成它,当我在前台运行它时,它工作正常,但是当我尝试将守护进程 fork 到后台时,它停止工作。我的
我正在尝试使用 Apache Commons Daemon 使用 Daemon 接口(interface)来守护我的应用程序。 Java 应用程序本身不执行任何操作,只是写入 stout。 我编译了j
我正在使用 Bootle Python Web Framework 在 Ubuntu 上开发网络应用程序。是否有任何有效的方法来守护启动默认 bottlepy 网络服务器的脚本? 谢谢。 UPD:现在
我一直使用 bluepill成功地守护简单的 Ruby 脚本。然而这一次,我有一个脚本,它也在加载 Rails 环境,因此我可以访问 Rails 应用程序及其各自模型的数据库连接。我使用的 bluep
我试图守护一些代码,但我遇到了一些麻烦。 如果我用 tklogger() 调用代码,它运行得很好。但是,如果我在守护程序上下文中调用它,我会得到以下跟踪信息: Traceback (most rece
我打算使用 systemd 将 celery 4.3.0 作为守护进程运行,但它给了我这个错误: 它会启动 worker 但会很快停止它们。但是,我可以通过键入以下命令手动运行工作人员: celery
我是一名优秀的程序员,十分优秀!