Linux文件共享(二)——两个独立进程打开同一个文件

  • 时间:
  • 浏览:1

将图3-2转化为linux下的具体实现,如下图所示。

总结:一4个多多独立tcp连接打开同一文件,对应不同的file对象,每个tcp连接调用close只影响本tcp连接的“打开文件计数”(file对象的引用计数)。

1leek定位到当前文件尾端,在向文件写入(write)与使用O_APPEND打开(open)文件再写入(write)的区别:

(2)   肯能用O_APPEND标志打开一4个多多文件,则相应标志也被设置到文件表项file对象)的文件情况标志中。每次对这些具有填写标志的文件执行写操作时,在文件表项中的当前文件位移量首先被设置为i节点表项中的文件长度。这就使得每次写的数据都去掉 到文件的当前尾端处。

 

肯能一4个多多独立tcp连接每个人 打开了同一文件,则有图3-2中所示的安排。亲戚朋友 假定第一4个多多tcp连接使该文件在文件描述符3上打开,而只有 tcp连接则使此文件在文件描述符4上打开。打开此文件的每一4个多多tcp连接都得到一4个多多文件对象但对一4个多多给定的文件只一4个多多多v节点表项。每个tcp连接不是每个人 的文件对象的一4个多多理由:这些安排使每个tcp连接不是它每个人 对该文件的当前位移量这些情况不要再增加对应的打开文件引用计数,而会增加dentry的引用。

第一4个多多tcp连接写入后,文件(i节点)的偏移肯能改变,第5个tcp连接再写会覆盖第一4个多多tcp连接刚写的内容。就是 用O_APPENDopen,会使内核每次对文件写时候,都将tcp连接的当前偏移量(file对象中的)设置到文件的尾端处(i节点的当前文件长度)。

前者是“非原子”操作,就是 一4个多多tcp连接都使用前者的法律最好的措施向文件结尾写入数据,只有 有肯能产生只有 的调度序列:

注:绿色次责为tcp连接1的私有资源,黄色次责为tcp连接2的私有资源,暗蓝色次责为tcp连接1、tcp连接2的共享资源。

(1) 在完成每一4个多多write后,在文件表项中的当前文件位移量即增加所写的字节数。如果这使当前文件位移量超过了当前文件长度,则在i节点表象中的当前文件长度被设置为当前文件位移量(也就是 该文件加长了)

(4)  若一4个多多文件用lseek被定位到文件当前的尾端,则文件表项中的当前文件位移量被设置为i节点表项中的当前文件长度。

扩展

       给出了什么数据社会形态后,现在对前面所述的操作作进一步说明。

(3)  lseek值修改文件表项中的当前文件位移量,只有 进行任何I/O操作。不影响i节点,只影响file对象,完整分析请见lvyilong316博客:空洞文件)

tcp连接Aleek  tcp连接Bleek tcp连接Awrite tcp连接Bwrite

注意对于多个tcp连接打开同一文件的情况,每个tcp连接不是它每个人 的文件表项file对象),其富含它每个人 的文件位移量,很多很多很多很多对于多个tcp连接读同一文件都能正确工作。有时候 ,当多个tcp连接写同一文件时,则肯能产生预期只有的结果。(不要再 使用preadpwrite)。