log-files – 如何强制进程刷新写入Linux下的打开文件描述符的数据?

我在嵌入式 Linux系统上运行了二进制进程(没有可用的源代码).该进程打开一个日志文件(/tmp/dmaosd.log),在该文件中记录它正在执行的操作.

问题是日志以块的形式更新(一次大约1000个字节),因此我无法使用tail -f实时查看日志.

我想知道是否有任何方法可以强制运行进程刷新其数据(基于访问/ proc / 1234 / fd / 3)而无需访问其源并且不向其发送任何信号(我不确定是什么信号它支持也不应该做什么).

有问题的过程是媒体播放器的OSD,日志信息通常显示屏幕上选择/显示的元素,因此尽可能快地获取数据会很好.

谢谢!

解决方法

它实际上取决于缓冲区的位置:如果应用程序使用自己的日志记录缓冲区,则无法强制刷新.

如果缓冲是由C库完成的,那么您可以使用LD_PRELOAD来禁用缓冲.假设程序使用fopen()打开其日志文件,您可以执行以下操作:

#define _GNU_SOURCE 1
#include <dlfcn.h>
#include <stdio.h>

static FILE* (*libc_fopen)(char const *,char const *);

FILE * fopen(char const *name,char const *mode) {
    FILE *ret;
    if (!libc_fopen)
        libc_fopen = dlsym(RTLD_NEXT,"fopen");

    ret = libc_fopen(name,mode);
    if (!ret)
        return ret;

    setvbuf(ret,NULL,_IONBF,0);

    return ret;
}

编译为共享库,然后使用LD_PRELOAD“注入”程序:

LD_PRELOAD=./nobuffering.so myprogram

如果需要,还可以检查文件名,并仅为您感兴趣的日志文件更改缓冲.

相关文章

1、安装Apache。 1)执行如下命令,安装Apache服务及其扩展包...
一、先说一下用ansible批量采集机器信息的实现办法: 1、先把...
安装配置 1. 安装vsftpd 检查是否安装了vsftpd # rpm -qa | ...
如何抑制stable_secret读取关键的“net.ipv6.conf.all.stabl...
1 删除0字节文件 find -type f -size 0 -exec rm -rf {} ...
## 步骤 1:安装必要的软件包 首先,需要确保系统已安装 `dh...