watch -n 1 'ps aux |sort -k 8 |grep R[+l] |tee -a 3.txt'
watch命令是为命令行输出设计的工具,其结果包含很多不可打印的字符,所以输出重定向到文件中很不方便,比如这样做的话有很多乱码:
(watch -n 60 <mycommand> ) >> file.log
所以可以的解决方法有两个
- 把输出结果的语句写到command里面
比如监控GPU的显存变化并写入日志
watch -n 3 'nvidia-smi -q -d MEMORY|tee -a gpu.log'
- 写脚本
while <some condition>
do
<mycommand> 2>&1 | tee -a /path/to/logfile
sleep 60
done
使用tee命令而不是重定向的原因是它可以将内容输出到标准输出设备的同时保存成文件
本文介绍了如何处理watch命令输出的乱码问题,提供了两种解决方案:一是通过在命令中直接调用输出语句,如监控GPU内存变化并写入日志;二是编写脚本,使用循环和tee命令同时输出到屏幕和日志文件。强调了使用tee命令在保持标准输出的同时保存文件的重要性。
1202





