【问题标题】:When running a ruby script via nohup, why doesn't puts write to nohup.out通过 nohup 运行 ruby​​ 脚本时,为什么不写入 nohup.out
【发布时间】:2018-02-15 01:18:15
【问题描述】:

我正在尝试使用 nohup 运行 ruby​​ 脚本:

nohup ruby​​ script.rb &

这需要几个小时才能运行,但会通过 puts 记录其进度。

通常,我可以查看 nohup.out 来查看我使用 nohup 运行的任何内容的最新输出。但是,我的 ruby​​ 脚本在完成或被杀死之前似乎没有输出任何内容。

我做错了什么?

【问题讨论】:

    标签: ruby linux ubuntu nohup


    【解决方案1】:

    我不熟悉通过nohup 运行命令,但是从“我正在将内容输出到文件并且仅在脚本退出后才写入”类型的问题来解决这个问题,这些问题是由输出引起的正在缓冲。

    所以很有可能通过nohup 运行(从而将puts 输出重定向到nohup.out)你失去了同步。您可能需要偶尔flush 或启用sync。因为puts 是“等价于$stdout.puts”:

    $stdout.flush # run this, occasionally
    # or just
    $stdout.sync = true
    

    【讨论】:

      猜你喜欢
      • 2019-01-17
      • 2011-01-12
      • 1970-01-01
      • 2011-12-22
      • 1970-01-01
      • 2015-11-19
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多