系统相关
首页 > 系统相关> > linux – 使用echo从多个进程并行写入文件

linux – 使用echo从多个进程并行写入文件

作者:互联网

我在ERP系统中编写了一个函数,通过简单地将其“回显”到日志文件中,将日志写入服务器上的文件.

echo "SOME LOGDATA" >> /users/erp/log/LOGMSG

每次用户触发特定事件时,都会调用LOG函数.

如果2个用户同时触发LOG事件会发生什么?

“echo”是否负责文件锁定?
在我看来,它必须是Linux内核或bash必须小心,文件不是由2个命令行指令同时写入.

我写了一个测试用例来强制这个条件(一秒内大约1000个LOG调用)似乎我的想法是对的,但我不能确定,这些调用是在bash上同时执行的.

解决方法:

正如here所解释的,只有当编写的序列短于PIPE_BUF和stdout缓冲区的大小(最有可能是BUFSIZ)时,才能保证回波是原子的.

对于更长的序列,您需要锁定.使用可以使用lockfile-create和lockfile-check.

标签:bash,linux,file-locking
来源: https://codeday.me/bug/20190611/1221086.html