微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐