From: "Darrick J. Wong" <djwong@kernel.org>
To: Baokun Li <libaokun1@huawei.com>
Cc: Theodore Ts'o <tytso@mit.edu>, Jan Kara <jack@suse.cz>,
"linux-ext4@vger.kernel.org" <linux-ext4@vger.kernel.org>,
Christian Brauner <brauner@kernel.org>,
sunyongjian1@huawei.com, Yang Erkun <yangerkun@huawei.com>,
linux-fsdevel@vger.kernel.org, linux-xfs@vger.kernel.org
Subject: Re: [BUG REPORT] ext4: “errors=remount-ro” has become “errors=shutdown”?
Date: Mon, 6 Jan 2025 23:08:20 -0800 [thread overview]
Message-ID: <20250107070820.GJ6174@frogsfrogsfrogs> (raw)
In-Reply-To: <0acc1709-1349-4dbb-ba3e-ae786c4b5b53@huawei.com>
On Tue, Jan 07, 2025 at 10:01:32AM +0800, Baokun Li wrote:
> On 2025/1/7 7:49, Darrick J. Wong wrote:
> > On Sat, Jan 04, 2025 at 10:41:28AM +0800, Baokun Li wrote:
> > > Hi Ted,
> > >
> > > On 2025/1/3 23:54, Theodore Ts'o wrote:
> > > > On Fri, Jan 03, 2025 at 10:35:17AM -0500, Theodore Ts'o wrote:
> > > > > I don't see how setting the shutdown flag causes reads to fail. That
> > > > > was true in an early version of the ext4 patch which implemented
> > > > > shutdown support, but one of the XFS developers (I don't remember if
> > > > > it was Dave or Cristoph) objected because XFS did not cause the
> > > > > read_pages function to fail. Are you seeing this with an upstream
> > > > > kernel, or with a patched kernel? The upstream kernel does *not* have
> > > > > the check in ext4_readpages() or ext4_read_folio() (post folio
> > > > > conversion).
> > > > OK, that's weird. Testing on 6.13-rc4, I don't see the problem simulating an ext4 error:
> > > >
> > > > root@kvm-xfstests:~# mke2fs -t ext4 -Fq /dev/vdc
> > > > /dev/vdc contains a ext4 file system
> > > > last mounted on /vdc on Fri Jan 3 10:38:21 2025
> > > > root@kvm-xfstests:~# mount -t ext4 -o errors=continue /dev/vdc /vdc
> > > We are discussing "errors=remount-ro," as the title states, not the
> > > continue mode. The key code leading to the behavior change is as follows,
> > > therefore the continue mode is not affected.
> > Hmm. On the one hand, XFS has generally returned EIO (or ESHUTDOWN in a
> > couple of specialty cases) when the fs has been shut down.
> Indeed, this is the intended behavior during shutdown.
> >
> > OTOH XFS also doesn't have errors=remount-ro; it just dies, which I
> > think has been its behavior for a long time.
> Yes. As an aside, is there any way for xfs to determine if -EIO is
> originating from a hardware error or if the filesystem has been shutdown?
XFS knows the difference, but nothing above it does.
> Or would you consider it useful to have the mount command display
> "shutdown" when the file system is being shut down?
Trouble is, will mount get confused and try to pass ",shutdown" as part
of a remount operation? I suppose the fs is dead so what does it
matter...
> > To me, it doesn't sound unreasonable for ext* to allow reads after a
> > shutdown when errors=remount-ro since it's always had that behavior.
> Yes, a previous bug fix inadvertently changed the behavior of
> errors=remount-ro,
> and the patch to correct this is coming.
>
> Additionally, ext4 now allows directory reads even after shutdown, is this
> expected behavior?
There's no formal specification for what shutdown means, so ... it's not
unexpected. XFS doesn't allow that.
> > Bonus Q: do you want an errors=fail variant to shut things down fast?
> >
> > --D
>
> In my opinion, I have not yet seen a scenario where the file system needs
> to be shut down after an error occurs. Therefore, using errors=remount-ro
> to prevent modifications after an error is sufficient. Of course, if
> customers have such needs, implementing this mode is also very simple.
IO errors, sure. Metadata errors? No, we want to stop the world
immediately, either so the sysadmin can go run xfs_repair, or the clod
manager can just kill the node and deploy another.
--D
>
>
> Thanks,
> Baokun
>
>
next prev parent reply other threads:[~2025-01-07 7:08 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <22d652f6-cb3c-43f5-b2fe-0a4bb6516a04@huawei.com>
[not found] ` <z52ea53du2k66du24ju4yetqm72e6pvtcbwkrjf4oomw2feffq@355vymdndrxn>
[not found] ` <17108cad-efa8-46b4-a320-70d7b696f75b@huawei.com>
2025-01-03 10:42 ` [BUG REPORT] ext4: “errors=remount-ro” has become “errors=shutdown”? Jan Kara
2025-01-03 13:19 ` Baokun Li
2025-01-03 14:34 ` Jan Kara
2025-01-04 3:15 ` Baokun Li
2025-01-03 15:35 ` Theodore Ts'o
2025-01-03 15:54 ` Theodore Ts'o
2025-01-04 2:41 ` Baokun Li
2025-01-06 23:49 ` Darrick J. Wong
2025-01-07 2:01 ` Baokun Li
2025-01-07 7:08 ` Darrick J. Wong [this message]
2025-01-08 2:08 ` Baokun Li
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250107070820.GJ6174@frogsfrogsfrogs \
--to=djwong@kernel.org \
--cc=brauner@kernel.org \
--cc=jack@suse.cz \
--cc=libaokun1@huawei.com \
--cc=linux-ext4@vger.kernel.org \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-xfs@vger.kernel.org \
--cc=sunyongjian1@huawei.com \
--cc=tytso@mit.edu \
--cc=yangerkun@huawei.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox