Sha256: 406900b3d56582c7d20d090411d4f9a260e72fa55b7c604dfaa7b351d219d563

Contents?: true

Size: 1.93 KB

Versions: 33

Compression:

Stored size: 1.93 KB

Contents

# Copyright (C) 2018-2019 MongoDB, Inc.

# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at

#  http://www.apache.org/licenses/LICENSE-2.0

# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

module Mongo
  class Server
    # @api private
    class RoundTripTimeAverager

      # The weighting factor (alpha) for calculating the average moving
      # round trip time.
      RTT_WEIGHT_FACTOR = 0.2.freeze
      private_constant :RTT_WEIGHT_FACTOR

      def initialize
        @last_round_trip_time = nil
        @average_round_trip_time = nil
      end

      attr_reader :last_round_trip_time
      attr_reader :average_round_trip_time

      def measure
        start = Time.now
        begin
          rv = yield
        rescue Exception => exc
        end
        last_round_trip_time = Time.now - start

        # If ismaster fails, we need to return the last round trip time
        # because it is used in the heartbeat failed SDAM event,
        # but we must not update the round trip time recorded in the server.
        unless exc
          @last_round_trip_time = last_round_trip_time
          update_average_round_trip_time
        end

        [rv, exc, last_round_trip_time, average_round_trip_time]
      end

      private

      # This method is separate for testing purposes.
      def update_average_round_trip_time
        @average_round_trip_time = if average_round_trip_time
          RTT_WEIGHT_FACTOR * last_round_trip_time + (1 - RTT_WEIGHT_FACTOR) * average_round_trip_time
        else
          last_round_trip_time
        end
      end
    end
  end
end

Version data entries

33 entries across 33 versions & 2 rubygems

Version Path
tdiary-5.1.6 vendor/bundle/ruby/2.7.0/gems/mongo-2.8.0/lib/mongo/server/round_trip_time_averager.rb
mongo-2.12.4 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.6 lib/mongo/server/round_trip_time_averager.rb
mongo-2.12.3 lib/mongo/server/round_trip_time_averager.rb
mongo-2.12.2 lib/mongo/server/round_trip_time_averager.rb
mongo-2.10.5 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.5 lib/mongo/server/round_trip_time_averager.rb
mongo-2.12.1 lib/mongo/server/round_trip_time_averager.rb
mongo-2.12.0.rc0 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.4 lib/mongo/server/round_trip_time_averager.rb
mongo-2.10.4 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.3 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.2 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.1 lib/mongo/server/round_trip_time_averager.rb
mongo-2.10.3 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.0 lib/mongo/server/round_trip_time_averager.rb
mongo-2.9.2 lib/mongo/server/round_trip_time_averager.rb
mongo-2.10.2 lib/mongo/server/round_trip_time_averager.rb
mongo-2.11.0.rc0 lib/mongo/server/round_trip_time_averager.rb
mongo-2.10.1 lib/mongo/server/round_trip_time_averager.rb