Re: Is ext3 flush data to disk when files are closed?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 2005-10-19 at 15:09 -0700, Andrew Morton wrote:
> Badari Pulavarty <[email protected]> wrote:
> >
> > On Wed, 2005-10-19 at 13:00 -0700, Andrew Morton wrote:
> > > Badari Pulavarty <[email protected]> wrote:
> > > >
> > > > On Wed, 2005-10-19 at 11:31 -0400, Xin Zhao wrote:
> > > > > As far as I know, if an application modifies a file on an ext3 file
> > > > > ssytem, it actually change the page cache, and the dirty pages will be
> > > > > flushed to disk by kupdate periodically.
> > > > > 
> > > > > My question is: if a file is to be closed, but some of its data pages
> > > > > are marked as dirty, will system block on close() and wait for dirty
> > > > > pages being flushed to disk? If so, it seems to decrease performance
> > > > > significantly if a lot of updates on many small files are involved.
> > > > > 
> > > > > Can someone point me to the right place to check how it works? Thanks!
> > > > 
> > > > On the last close() of the file, it should be flushed through ..
> > > > 
> > > > 	iput_final() -> generic_drop_inode() -> write_inode_now()
> > > > 		-> __writeback_single_inode() -> __sync_single_inode()
> > > > 			-> do_writepages()
> > > 
> > > The dcache's reference to the inode will prevent this from happening at
> > > close() time.
> > > 
> > 
> > I thought so too, till I wrote a kprobe/systemtap script to print 
> > the callers of generic_forget_inode() earlier and saw that most 
> > of my stacks are from exit() or close().
> > 
> >  0xffffffff801a0222 : generic_drop_inode+0x2/0x170 []
> >  0xffffffff8019eeb0 : iput+0x50/0x90 []
> >  0xffffffff8019c7bb : dput+0x1db/0x220 []
> >  0xffffffff80184461 : __fput+0x171/0x1e0 []
> >  0xffffffff801829ce : filp_close+0x6e/0x90 []
> >  0xffffffff801388eb : put_files_struct+0x6b/0xc0 []
> >  0xffffffff801392ef : do_exit+0x1ff/0xbb0 []
> >  
> 
> But generic_forget_inode usually doesn't dispose of the inode.
> 
> 	if (!hlist_unhashed(&inode->i_hash)) {
> 		if (!(inode->i_state & (I_DIRTY|I_LOCK)))
> 			list_move(&inode->i_list, &inode_unused);
> 		inodes_stat.nr_unused++;
> 		if (!sb || (sb->s_flags & MS_ACTIVE)) {
> 			spin_unlock(&inode_lock);
> 			return;
> 		}

Okay, makes sense. 

Thanks,
Badari

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux