Commit Graph

79376 Commits

Author SHA1 Message Date
Sage Weil
7debd61f8b osd/PG: make update_snap_mapper_bits public
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
25769b2736 osd/PG: make on_removal() public
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
c4616eec28 osd/PG: make get_primary() public
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
17e6d40080 osd/PG: add get_pool()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
070181a9e5 osd: use pg_id.pool() for pg pool id
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
24af955d02 osd/PG: make sched_scrub() public
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
88c13308b6 osd/PG: get_must_scrub()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
d14cc56157 osd/PGBackend: remove scrub_supported()
Everybody supports scrub.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
2a3a3fdae7 osd/PG: change 'debug dump_missing'
- json
- move into PG class

No users in the qa suite.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
79e7dbb80c osd/PG: move bits of delete_dir (pg removal) into PG
We don't want to expose things like SnapMapper, OSDriver.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
b8f33aab64 osd/PG: define public interface for heartbeat peers
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
d36c468647 osd: use accessors for pg resurrection
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
7a4f30d8a6 osd/PG: simplify start_recovery_ops return value meaning
Instead of complex check in caller, return simple bool indicating whether
find_unfound() should be called with a rctx.

There is one remaining condition that can probably be simplified:

  if (!recovering.empty() ||
      work_in_progress || recovery_ops_active > 0 || deferred_backfill)
    return !work_in_progress && have_unfound();

but we will leave it for now.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
e5405feada osd/PG: simplify unfound recovery case; rename method
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
82077e7116 osd/PG: drop unneeded write_if_dirty
Nothing in start_recovery_ops or stuck_on_unfound dirties state.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
b3b8119585 osd/PG: move a few assertions, flag change into start_recovery_ops()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
81f93729ff osd/PG: move some more split machinery into PG
and move other split pieces into the public interface.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
fa7818aefa osd/PG: move write_if_dirty inside handle_{loaded,create}
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
043816396c osd/PG: get_need_up_thru(), get_same_interval_since()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
f542b2014e osd: bit less verbose while loading pgs
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
6493f8ec5a osd/PG: move more recovery logic into PG
I suspect we eventually want to move the create_context and
dispatch_context into OSDService (if it isn't there already) and move
even more of this logic into PG.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
ea169c1bf2 osd/PG: move some osd logic into handle_pg_trim
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
43265b2310 osd/PG: hide peering_queue from OSD
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
ac9e2f7609 osd: remove build_past_intervals_parallel
This was added in the dumpling era to handle the case where we have lots
of PGs with stale or missing past_intervals.  These days, we update
PastIntervals as we inject new makes (via advance_map), when we
learn about new PGs via notify with get the PastIntervals at the same time,
and during PGCreate handling we have a separate path in
build_initial_pg_history.  This code is obsolete.

It also reaches deep into the PG class where it shouldn't!

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
602203819a osd: use PG::is_deleting()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
342d68189f osd/PG: move load_pgs cruft into read_state()
This only happens during initial load; move it there.

Also, since update_store_with_options

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:18 -05:00
Sage Weil
662bb8f430 osd/PG: make read_state, peek_map_epoch public
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
48f4126507 osd/PG: simplify/streamline upgrade process
There's no reason for this to be exposed to the OSD.  Just do it directly
in read_state().

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
9dfa72454e osd/PG: drop bufferlist passed from peek_map_epoch to read_state/read_info
This is no longer used or needed.

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
3b70a35e7b osd/PG: make init() public
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
80233f28d4 osd/PG: on_shutdown -> shutdown in public interface
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
1b81002920 osd/PG: add get_num_ref()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
385cda10a2 osd/PG: add get_pg_stats() to public interface
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
7908142647 osd/PG: add dump_pgstate_history() to public interface
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
5cef6cad4b osd/PG: make get_watchers public, hide locking
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
72d50e463f osd: drop legacy infos object cleanup
This won't be there post-luminous

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
83a3513e95 osd/PG: make osr public
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
923ca75443 osd: use is_deleting()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
329eb60596 osd: use pg->pg_id const member, not get_pgid()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
9ab4eebcaf osd/PG: reorder some members
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
49aeb040ee osd/PG: protect get_last_peering_reset
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
c4a9fdf8cd osd/PG: protect get_role()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
8921301418 osd/PG: cleanup and move ref counting public bits
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
e70067c685 osd/PG: protect pg state accessors
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
7abb015d54 osd/PG: add is_forced_recovery_or_backfill()
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
50a6f3c59c osd/ECBackend: use Listener instead of PG interface to check undersized
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
931fc923c3 osd/PG: collection more of public at top of class
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
c3b300d9b2 osd/PG: expose static methods for ceph-objectstore-tool
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
ca4ba9b4f6 osd/PG: move C_PG_FinishRecovery into header
Less code than delcaring it in 2 places (by making it a friend).

Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00
Sage Weil
059158569c osd/PG: move C_PG_ActivateCommitted into header
Signed-off-by: Sage Weil <sage@redhat.com>
2017-10-06 13:08:17 -05:00