python输出日志out.log相关问题(缓存机制)

现象:nohup python total_test619.py > out.log 2>&1 &,total_test619.py功能如下,首先计算1+3的值,然后将该值print出来,之后等待5分钟,重新运行之前的函数,输出结果,之后往复,等待时间,输出结果等,这个里面是输出的日志为什么在程序刚开始运行的时候会输出内容,等等代理5min后,第二次运行函数的时候,结果就不输出到out.log中了。

解释:

在执行 nohup python total_test619.py > out.log 2>&1 & 命令时,你可能遇到第二次运行函数时结果不再输出到 out.log 文件中的问题。这通常是由于 Python 的输出缓冲机制导致的。

Python 在处理输出时,会有一个输出缓冲区。当使用 print 语句时,输出不会立即写入到文件中,而是先存储在内存中的缓冲区里。只有当缓冲区满或者遇到 flush 操作时,输出才会真正写入到文件或其他目的地。

在这个例子中,如果你在程序中没有加入 flush 操作,或者缓冲区设置得比较大,你可能会发现,只有当缓冲区刷新时,输出才会写入到 out.log 文件中。这通常发生在程序结束或者缓冲区自然刷新时。

为了解决这个问题,可以在 print 语句中加入 flush 关键词,强制刷新缓冲区,确保输出及时写入到文件中。例如:

python 复制代码
print("Hello", flush=True)

这样,每次 print 都会将输出立即写入到文件中,而不是等待缓冲区刷新。这可以确保你在需要的时间内看到预期的输出

相关推荐
kobesdu1 小时前
【ROS2实战笔记-19】ROS2 生命周期节点的启动顺序、状态转换陷阱与热备方案
java·前端·笔记·机器人·ros·ros2
nuowenyadelunwen1 小时前
CS 61A Lab 2 笔记:短路求值、高阶函数与 Lambda 表达式
python·函数式编程·cs61a·berkeley
neo_Ggx231 小时前
Maven 版本管理详解:SNAPSHOT、Release 与 Nexus 仓库的区别和影响
java·maven
matlabgoodboy1 小时前
软件开发定制小程序APP帮代做java代码代编写C语言设计python编程
java·c语言·小程序
江离w1 小时前
新版vibecoding项目初始化指令
java
tongluowan0072 小时前
Spring MVC 底层工作流程+源码分析
java·spring·mvc
qq_422828622 小时前
android图形学之SurfaceControl和Surface的关系 五
android·开发语言·python
weixin_444012932 小时前
c++如何将std--vector直接DUMP到二进制文件_指针地址直写【附代码】
jvm·数据库·python
woxihuan1234562 小时前
Go语言中--=运算符详解:位右移赋值操作的原理与应用
jvm·数据库·python
java1234_小锋2 小时前
SpringBoot为什么要禁止循环依赖?
java·数据库·spring boot