明明打印到文件了,为啥tail -f看不到

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了明明打印到文件了,为啥tail -f看不到相关的知识,希望对你有一定的参考价值。

文章《一分钟了解nohup和&的功效》留了一个“nohup.out为啥没有包含stdout输出”的尾巴,今天把坑填了。
技术图片

测试代码是一个打印hello与循环轮数的死循环程序,每打印一行就休眠1秒。
技术图片

使用./a.out 运行程序后,每隔一秒会在终端输出一个字符串。
技术图片

使用nohup ./a.out运行程序后,有一个“忽略输入,输出至nohup.out”的提示。

技术图片
把程序killall干掉之后,果然有一个nohup.out生成。

不过这个文件的大小是0,有点奇怪,启动程序的时候,明明提示了“appending output to nohup.out”呀,这是为什么呢?原本打印在终端的hello字符串去哪里了呢?

留言里不少同学猜测和2>&1 >/dev/null有关,但其实本例并未将标准输出,标准错误输出重定向。

nohup.out未能及时输出,是因为nohup后,为了提高性能stdout启用了缓冲,并不会实时把内容写入文件,只有当缓冲写满了才会刷盘。killall程序时,还来不及刷盘程序就退出了,于是出现了空nohup.out文件。

如果想要实时刷盘,可以选择:

  • 把缓冲设为空,setbuf(stdout, NULL)
  • 强制刷盘,fflush(stdout)

技术图片
如上图,程序添加一行“fflush(stdout)”之后,再次测试。
技术图片

就能够看到nohup.out会实时的刷新数据啦。

遗留:

  • 评论里说的2>&1 >/dev/null 是什么鬼?
  • 打印日志的时候,是需要实时刷新,还是缓存刷新呢?

额,上一篇《一分钟了解nohup和&的功效》,介绍了一个linux小知识,就被喷得厉害,评论说文章拉低了58的技术水准,下一篇回归架构,介绍“全链路调用链跟踪架构”以及“如何在小公司快速落地全链路调用链跟踪实践”。

相关推荐:
《linux下追查线上问题常用命令》
《线上服务内存OOM问题定位三板斧》
《线上服务CPU100%问题快速定位实战》
《一分钟sed手册》
《一分钟awk手册》

以上是关于明明打印到文件了,为啥tail -f看不到的主要内容,如果未能解决你的问题,请参考以下文章

linux查看文件的某几行

pandas库明明安装成功了,为啥总是导入错误?

在电脑访问nas文件不用登陆也不用密码,明明设置好了这是为啥

为啥哈罗小程序明明发出了信息为啥过后没有了

新人学vue,我明明导入了vue.js文件,但是data里面的数据就是不显示,这是为啥啊

将字符串打印到文件,为啥需要额外的位?