2012-07-11 00:52:21 +00:00
|
|
|
====
|
|
|
|
PG
|
|
|
|
====
|
|
|
|
|
|
|
|
Concepts
|
|
|
|
--------
|
|
|
|
|
|
|
|
*Peering Interval*
|
|
|
|
See PG::start_peering_interval.
|
2013-05-14 10:06:21 +00:00
|
|
|
See PG::acting_up_affected
|
2019-04-12 18:08:54 +00:00
|
|
|
See PG::PeeringState::Reset
|
2012-07-11 00:52:21 +00:00
|
|
|
|
|
|
|
A peering interval is a maximal set of contiguous map epochs in which the
|
2019-04-12 18:08:54 +00:00
|
|
|
up and acting sets did not change. PG::PeeringMachine represents a
|
2012-07-11 00:52:21 +00:00
|
|
|
transition from one interval to another as passing through
|
2019-04-12 18:08:54 +00:00
|
|
|
PeeringState::Reset. On PG::PeeringState::AdvMap PG::acting_up_affected can
|
2012-07-11 00:52:21 +00:00
|
|
|
cause the pg to transition to Reset.
|
|
|
|
|
|
|
|
|
|
|
|
Peering Details and Gotchas
|
|
|
|
---------------------------
|
2013-05-14 10:06:21 +00:00
|
|
|
For an overview of peering, see `Peering <../../peering>`_.
|
2012-07-11 00:52:21 +00:00
|
|
|
|
|
|
|
* PG::flushed defaults to false and is set to false in
|
2019-04-12 18:08:54 +00:00
|
|
|
PG::start_peering_interval. Upon transitioning to PG::PeeringState::Started
|
2012-07-11 00:52:21 +00:00
|
|
|
we send a transaction through the pg op sequencer which, upon complete,
|
|
|
|
sends a FlushedEvt which sets flushed to true. The primary cannot go
|
2019-04-12 18:08:54 +00:00
|
|
|
active until this happens (See PG::PeeringState::WaitFlushedPeering).
|
2012-07-11 00:52:21 +00:00
|
|
|
Replicas can go active but cannot serve ops (writes or reads).
|
|
|
|
This is necessary because we cannot read our ondisk state until unstable
|
|
|
|
transactions from the previous interval have cleared.
|