]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/commit
gmirror: Evaluate mirror components against newest metadata copy
authorcem <cem@FreeBSD.org>
Fri, 7 Dec 2018 02:44:04 +0000 (02:44 +0000)
committercem <cem@FreeBSD.org>
Fri, 7 Dec 2018 02:44:04 +0000 (02:44 +0000)
commit42d84ef531f1a4c40f63f803d89d4813b8241b8f
treeb756edefc76586d5d1f946de9b9d0b4526e75cdd
parenta6f65b400837be27223e51700d9615c669800603
gmirror: Evaluate mirror components against newest metadata copy

Re-apply r341665 with format strings fixed.

If we happen to taste a stale mirror component first, don't reject valid,
newer components that have differing metadata from the stale component
(during STARTING).  Instead, update our view of the most recent metadata as
we taste components.

Like mediasize beforehand, remove some checks from g_mirror_check_metadata
which would evict valid components due to metadata that can change over a
mirror's lifetime.  g_mirror_check_metadata is invoked long before we check
genid/syncid and decide which component(s) are newest and whether or not we
have quorum.

Before checking if we can enter RUNNING (i.e., we have quorum) after a NEW
component is added, first remove any known stale or inconsistent disks from
the mirrorset, rather than removing them *after* deciding we have quorum.
Check if we have quorum after removing these components.

Additionally, add a knob, kern.geom.mirror.launch_mirror_before_timeout, to
force gmirrors to wait out the full timeout (kern.geom.mirror.timeout)
before transitioning from STARTING to RUNNING.  This is a kludge to help
ensure all eligible, boot-time available mirror components are tasted before
RUNNING a gmirror.

Add a basic test case for STARTING -> RUNNING startup behavior around stale
genids.

PR: 232671, 232835
Submitted by: Cindy Yang <cyang AT isilon.com> (previous version)
Reviewed by: markj (kernel portions)
Discussed with: asomers, Cindy Yang
Tested by: pho
Sponsored by: Dell EMC Isilon
Differential Revision: https://reviews.freebsd.org/D18062
sys/geom/mirror/g_mirror.c
sys/geom/mirror/g_mirror.h
tests/sys/geom/class/mirror/Makefile
tests/sys/geom/class/mirror/component_selection.sh [new file with mode: 0755]
tests/sys/geom/class/mirror/conf.sh