2013-10-29 21 views
0

这是我的一个未解决的考题。 两个Unix进程可以同时写入单个文件中的不同位置 吗?两个Unix进程可以同时写入单个文件中的不同位置吗?

  1. 是,这两个过程都会有自己的文件表项
  2. 没有,共享i节点包含了一个偏移指针
  3. 只有一个进程将有写权限
  4. 是的,但只如果我们经营使用NFS
+0

这是一个家庭作业/测试问题,不是吗? – PaulProgrammer

+0

@PaulProgrammer是tbh。 – Disasterkid

+2

这是一条提示,其中三条回复不正确。 – jlliagre

回答

1
  • inode中没有记录偏移,所以回答2不正确。
  • 进程没有修改其访问权限的记录原因,因此3.不正确。
  • NFS允许不同主机上的进程同时访问,这里的问题是针对同一主机上的进程,因此NFS不应有所作为。

这里是一个shell脚本演示剩下的答案1.正确的是:

# create a 10m file 
dd if=/dev/zero of=/var/tmp/file bs=1024k count=10 

# create two 1 MB files 
cd /tmp 
printf "aaaaaaaa" > aa 
printf "bbbbbbbb" > bb 
i=0 
while [ $i -lt 17 ]; do 
    cat aa aa > aa.new && mv aa.new aa 
    cat bb bb > bb.new && mv bb.new bb 
    i=$((i+1)) 
done 

ls -lG /var/tmp/file /tmp/aa /tmp/bb 

# launch 10 processes that will write at different locations in the same file. 
# Uses dd notrunc option for the file not to be truncated 
# Uses GNU dd fdatasync option for unbuffered writes 

i=0 
while [ $i -lt 5 ]; do 
    (
    dd if=/tmp/aa of=/var/tmp/file conv=notrunc,fdatasync bs=1024k count=1 seek=$((i*2)) 2>/dev/null & 
    dd if=/tmp/bb of=/var/tmp/file conv=notrunc,fdatasync bs=1024k count=1 seek=$((i*2+1)) 2>/dev/null & 
) & 
    i=$((i+1)) 
done 

# Check concurrency 
printf "\n%d processes are currently writing to /var/tmp/file\n" "$(fuser /var/tmp/file 2>/dev/null | wc -w)" 

# Wait for write completion and check file contents 
wait 
printf "/var/tmp/file contains:\n" 
od -c /var/tmp/file 

它的输出显示成功,同时10个过程写同样的文件:

-rw-r--r-- 1 jlliagre 1048576 oct. 30 08:25 /tmp/aa 
-rw-r--r-- 1 jlliagre 1048576 oct. 30 08:25 /tmp/bb 
-rw-r--r-- 1 jlliagre 10485760 oct. 30 08:25 /var/tmp/file 

10 processes are currently writing to /var/tmp/file 

/var/tmp/file contains: 
0000000 a a a a a a a a a a a a a a a a 
* 
4000000 b b b b b b b b b b b b b b b b 
* 
10000000 a a a a a a a a a a a a a a a a 
* 
14000000 b b b b b b b b b b b b b b b b 
* 
20000000 a a a a a a a a a a a a a a a a 
* 
24000000 b b b b b b b b b b b b b b b b 
* 
30000000 a a a a a a a a a a a a a a a a 
* 
34000000 b b b b b b b b b b b b b b b b 
* 
40000000 a a a a a a a a a a a a a a a a 
* 
44000000 b b b b b b b b b b b b b b b b 
* 
50000000 
1

是的,他们当然可以,有以下注意事项:

  • 根据open()模式,一个过程可以很容易地擦拭文件内容
  • 根据日程安排,写操作的顺序不确定性
  • 没有强制的锁定(一般) - 精心设计要求咨询锁定。
  • 如果他们使用缓冲I/O写入相同区域,结果可能不确定。
1

定义

是的,这两个进程将有自己的文件表条目。

如果使用open函数打开文件两次,则会创建两个文件描述符。

每个文件描述符都有单独的文件状态标志。

所以两个文件描述符都有一个写权限文件描述符1和文件描述符2的起始位置指向第一个字符到文件。

如果我们在描述符和写入文件中指定了一些位置,可以很容易地进行测试。

file.txt的内容

我叫Chandru。这是一个空文件。

编码来进行测试:

#include<stdio.h>                   
#include<fcntl.h> 
#include<stdlib.h> 


main() 
{ 
    int fd1, fd2; 

if((fd1=open("file.txt", O_WRONLY)) <0){ 
      perror("Error"); 
      exit(0); 
    } 
    if((fd2=open("file.txt", O_WRONLY)) < 0) { 
      perror("Error"); 
      exit(0); 
    } 
    if(lseek(fd1,20,SEEK_SET) != 20) 
    { 
      printf("Cannot seek\n"); 
      exit(0); 
    } 
    if(write(fd1,"testing",7) != 7) 
    { 
      printf("Error write\n"); 
      exit(0); 
    } 
    if(lseek(fd2,10,SEEK_SET) != 10) 
    { 
      printf("Cannot seek\n"); 
      exit(0); 
    } 
    if(write(fd2,"condition",9) != 9) 
    { 
      printf("Error write\n"); 
      exit(0); 
    } 
    } 

输出: 后,我的输出是

我的名字isconditionitesting空文件。

+0

虽然您显示同一个文件的多个文件描述符可以同时存在,这确实是主要问题,但您并没有真正回答关于写入同一文件的两个不同进程的问题,而不是单个进程。 – jlliagre

相关问题