All of lore.kernel.org
 help / color / mirror / Atom feed
* [XFS SUMMIT] Deprecating V4 on-disk format
@ 2020-05-13  2:36 Dave Chinner
  2020-05-19  6:23 ` Darrick J. Wong
  0 siblings, 1 reply; 10+ messages in thread
From: Dave Chinner @ 2020-05-13  2:36 UTC (permalink / raw)
  To: linux-xfs


Topic: Deprecating V4 On-disk Format

Scope:
	Long term life cycle planning
	Supporting old filesystems with new kernels.
	Unfixable integrity issues in v4 format.
	Reducing feature matrix for testing

Proposal:

The CRC-enabled V5 format has been the upstream default format now
since commit 566ebd5ae5fa ("mkfs: default to CRC enabled
filesystems") dated May 11 2015 (5 years ago!) and released in
xfsprogs v3.2.3. It is the default in all major distros, and has
been for some time.

We know that the v4 format has unfixable integrity issues apart from
the obvious lack of CRCs and self-describing metadata structures; it
has race conditions in log recovery realted to inode creation and
other such issues that could only be solved with an on-disk format
change of some kind. We are not adding new features to v4 formats,
so anyone wanting to use new XFS features must use v5 format
filesystems.

We also know that the number of v4 filesysetms in production is
slowly decreasing as systems are replaced as part of the natural
life cycle of production systems.

All this adds up to the realisation that existing v4 filesystems are
effectively in the "Maintenance Mode" era of the software life
cycle. The next stage in the life cycle is "Phasing Out" before we
drop support for it altogether, also know around here as
"deprecated" which is a sign that support will "soon" cease.

I'd like to move the v4 format to the "deprecated" state as a signal
to users that it should really not be considered viable for new
systems. New systems running modern kernels and userspace should
all be using the v5 format, so this mostly only affects existing
filesystems.

Note: I am not proposing that we drop support for the v4 format any
time soon. What I am proposing is an "end of lifecycle" tag similar
to the way we use EXPERIMENTAL to indicate that the functionality is
available but we don't recommend it for production systems yet.

Hence what I am proposing is that we introduce a DEPRECATED alert at
mount time to inform users that the functionality exists, but it
will not be maintained indefinitely into the future. For distros
with a ten year support life, this means that a near-future release
will pick up the DEPRECATED tag but still support the filesystem for
the support life of that release. A "future +1" release may not
support the v4 format at all.

Discussion points:

- How practical is this?
- What should we have mkfs do when directed to create a v4 format
  filesystem?
- How long before we decide to remove v4 support from the upstream
  kernel and tools? 5 years after deprecation? 10 years?

Cheers,

Dave.
-- 
Dave Chinner
david@fromorbit.com

^ permalink raw reply	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2020-05-26 17:16 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-05-13  2:36 [XFS SUMMIT] Deprecating V4 on-disk format Dave Chinner
2020-05-19  6:23 ` Darrick J. Wong
2020-05-20  1:14   ` Dave Chinner
2020-05-20 13:15     ` Emmanuel Florac
2020-05-21  8:29       ` Mike Fleetwood
2020-05-26 17:16         ` Eric Sandeen
2020-05-25  3:23       ` Dave Chinner
2020-05-25  6:08         ` Darrick J. Wong
2020-05-25  7:02           ` Amir Goldstein
2020-05-25 10:01         ` Emmanuel Florac

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.