[Top] [All Lists]

Premature "No Space left on device" on XFS

To: xfs@xxxxxxxxxxx
Subject: Premature "No Space left on device" on XFS
From: Bernhard Schmidt <berni@xxxxxxxxxxxxx>
Date: Thu, 06 Oct 2011 21:55:07 +0200
Dkim-signature: v=1; a=rsa-sha256; c=relaxed/simple; d=birkenwald.de; h= content-transfer-encoding:content-type:content-type:subject :subject:mime-version:user-agent:from:from:date:date:message-id :received; s=mailout; t=1317930908; bh=g5MGG/gAbwS76xH6Xbz/Ox/km kqrBS62H3UG4LoMRWw=; b=DojlilYPeIZHbzUJXu3WGzHfreuHLJKiEbN8f8d/7 pyLXFtqkQt7raCbm+OyO8mu7HsaoIeDl9ymaOtIwvo7sfm2Z6UBqojPdn+p6/3eE cSIHJOVDw8l6rTrJ67tKE9NKTbLj73AU7XFZBTc46WVixbXBbjdOGzM89ggzTCtK yg=
User-agent: Mozilla/5.0 (X11; Linux i686; rv:7.0.1) Gecko/20110929 Thunderbird/7.0.1

this is an XFS-related summary of a problem report I sent to the postfix mailinglist a few minutes ago after a bulkmail test system blew up during a stress test.

We have a few MTAs running SLES11.1 amd64 (, 10 GB XFS Spooldirectory with default blocksize (4k). It was bombarded with mails faster than it could send them on, which eventually led to almost 2 million files of ~1.5kB in one directory. Suddenly, this started to happen

lxmhs45:/var/spool/postfix-bulk/postfix-bulkinhss # touch a
touch: cannot touch `a': No space left on device
lxmhs45:/var/spool/postfix-bulk/postfix-bulkinhss # df .
Filesystem           1K-blocks      Used Available Use% Mounted on
/dev/sdb 10475520 7471160 3004360 72% /var/spool/postfix-bulk
lxmhs45:/var/spool/postfix-bulk/postfix-bulkinhss # df -i .
Filesystem            Inodes   IUsed   IFree IUse% Mounted on
/dev/sdb             10485760 1742528 8743232   17% /var/spool/postfix-bulk

So we could not create any file in the spool directory anymore despite df claiming to have both free blocks and inodes. This led to a pretty spectacular lockup of the mail processing chain.

My theory is that XFS is using a full 4k block for each 1.5kB file, which accounts to some loss. But still, 10GB / 4kB makes 2.5 mio files, which have surely not been reached here. Is there that high overhead? Why is neither df-metric reporting this problem? Is there any way to get reasonable readings out of df in this case? The system would have stopped accepting mail from outside if the freespace would have sunk below 2GB, so out-of-space happened way to early for it.

Thanks for your answers,

<Prev in Thread] Current Thread [Next in Thread>