多进程、多线程并发写同一log文件问题


多进程并发写同一个log文件问题

两个独立进程各自打开同一个文件



如果用O_APPEND标志打开了一个文件,则相应标志也被设置到文件表项的文件状态标志中。每次对这种具有添写标志的文件执行写操作时,在文件表项中的当前文件偏移量首先被设置为i节点表项中的文件长度。这就使得每次写的数据都添加到文件的当前尾端处。


UNIX系统提供了一种方法使得以下操作成为原子操作,该方法是在打开文件时设置O_APPEND标志。正如前面所述,这就是内核每次对这种文件进行写之前,都将进程的当前偏移量设置到文件的尾端处,于是在每次写之前就不在需要调用sleek了。

  1. if (lseek(fd, 0L, 2) < 0) /* position to EOF */

  2. err_sys("lseek error");

  3. if (write(fd, buf, 100) != 100) /* and write */

  4. err_sys("write error");



即,使用fopen以"a"追加模式打开时,多个进程写同一log文件不会发送覆盖写的问题,每次都保证在文件末尾写。





评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值