Skip to content

Commit

Permalink
server: (re-)fix data race in server initialization
Browse files Browse the repository at this point in the history
Fixes #91414.
Fixes  #101010.
Fixes #100902.

There was a race between registerEnginesForDiskStatsMap and
SetPebbleMetricsProvider, the latter making use of a map constructed by
the former but appeared in the opposite order in code.

Release note: None
  • Loading branch information
irfansharif committed Apr 10, 2023
1 parent 10762f4 commit 83ffd45
Showing 1 changed file with 9 additions and 0 deletions.
9 changes: 9 additions & 0 deletions pkg/server/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -1534,6 +1534,15 @@ func (s *Server) PreStart(ctx context.Context) error {
// stores)
s.node.waitForAdditionalStoreInit()

// Connect the engines to the disk stats map constructor. This needs to
// wait until after waitForAdditionalStoreInit returns since it realizes on
// wholly initialized stores (it reads the StoreIdentKeys). It also needs
// to come before the call into SetPebbleMetricsProvider, which internally
// uses the disk stats map we're initializing.
if err := s.node.registerEnginesForDiskStatsMap(s.cfg.Stores.Specs, s.engines); err != nil {
return errors.Wrapf(err, "failed to register engines for the disk stats map")
}

// Stores have been initialized, so Node can now provide Pebble metrics.
//
// Note that all existing stores will be operational before Pebble-level
Expand Down

0 comments on commit 83ffd45

Please sign in to comment.