Clase: Mongo::Server::Monitor Privado

Hereda:
Objeto
  • Objeto
Mostrar todo
Ampliado por:
Reenviable
Incluye:
BackgroundThread, Event::Publisher, Loggable
Definido en:
lib/mongo/server/monitor.rb,
lib/mongo/server/monitor/connection.rb,
lib/mongo/server/monitor/app_metadata.rb

Overview

Esta clase forma parte de una API privada. Evita usar esta clase si es posible, ya que puede ser eliminada o modificada en el futuro.

Responsable de realizar consultas periódicas a un servidor a través de comandos hello para mantener actualizado el estado del servidor.

Realiza todo el trabajo en un hilo en segundo plano para no interferir con otras operaciones realizadas por el driver.

Desde:

  • 2.0.0

Definido bajo Namespace

clase: AppMetadata, Connection

Resumen de constantes colapsar

DEFAULT_HEARTBEAT_INTERVAL =

Esta constante es parte de una API privada. Deberías evitar usar esta constante si es posible, ya que podría ser retirada o cambiada en el futuro.

El intervalo por defecto entre actualizaciones del estado del servidor es de 10 segundos.

Desde:

  • 2.0.0

10
MIN_SCAN_INTERVAL =

Esta constante es parte de una API privada. Deberías evitar usar esta constante si es posible, ya que podría ser retirada o cambiada en el futuro.

El tiempo mínimo entre escaneos forzados del servidor. minHeartbeatFrequencyMS en la especificación SDAM.

Desde:

  • 2.0.0

0.5
RTT_WEIGHT_FACTOR =

Esta constante es parte de una API privada. Deberías evitar usar esta constante si es posible, ya que podría ser retirada o cambiada en el futuro.

Obsoleto.

Se eliminará en la versión 3.0.

El factor de ponderación (alfa) para calcular el tiempo promedio de ida y vuelta en movimiento.

Desde:

  • 2.0.0

0.2

Constantes incluidas desde Loggable

Loggable::PREFIX

Resumen de atributos de la instancia colapsar

Atributos incluidos de Event::Publisher

#event_listeners

Resumen del método de instancia colapsar

Métodos incluidos de BackgroundThread (Hilo de fondo)

#¡corre!, #¿corriendo?

Métodos incluidos desde Registrable

#log_debug, #log_error, #log_fatal, #log_info, #log_warn, #logger

Métodos incluidos de Event::Publisher

#publicar

Detalles del Constructor

#inicializar(servidor, listeners_de_eventos, supervisión, opciones = {}) ⇒ Monitor

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Nota:

El monitor nunca debe ser instanciado directamente fuera de un servidor.

Cree el nuevo monitor de servidor.

Ejemplos:

Crear para supervisar el servidor.

Mongo::Server::Monitor.new(address, listeners, monitoring)

Parámetros:

  • Server (servidor)

    El servidor a supervisar.

  • event_listeners (Event::Listeners)

    Los evento listeners.

  • Monitoring (supervisión)

    La supervisión.

  • opciones (encriptada) (por defecto: {})

    Las opciones.

Opciones Hash (options):

  • timeout_conexión (Flotante)

    El tiempo de espera, en segundos, que debe utilizarse al establecer la conexión de supervisión.

  • intervalo de latidos (Flotante)

    El intervalo entre comprobaciones regulares del servidor.

  • :logger (Logger)

    Un registrador personalizado para usar.

  • :monitor_app_metadata (Mongo::servidor::supervisar::AppMetadata)

    Los metadatos que se utilizarán para la conexión de supervisión regular.

  • :push_monitor_app_metadata (Mongo::servidor::supervisar::AppMetadata)

    Los metadatos que se usarán para la conexión del monitor de envío.

  • timeout_del_socket (Flotante)

    El tiempo de espera, en segundos, para ejecutar operaciones en la conexión de supervisión.

Aumenta:

  • (ArgumentError)

Desde:

  • 2.0.0



76
77
78
79
80
81
82
83
84
85
86
87
88
89
# Archivo 'lib/mongo/server/monitor.rb', línea 76

def inicializar(Server, event_listeners, Monitoring, opciones = {})
  propagar ArgumentError, "Tipo de supervisión incorrecto: #{supervisión.inspect}" a menos que Monitoring.is_a?(Monitoring)
  propagar ArgumentError, 'Los metadatos de la aplicación son obligatorios' a menos que opciones[:app_metadata]
  propagar ArgumentError, 'Los metadatos de la aplicación de monitor de notificaciones son obligatorios' a menos que opciones[:push_monitor_app_metadata]

  @server = Server
  @event_listeners = event_listeners
  @monitoring = Monitoring
  @options = opciones.freeze
  @mutex = Mutex (exclusión mutua).Nuevo
  @sdam_mutex = Mutex (exclusión mutua).Nuevo
  @next_earliest_scan = @next_wanted_scan = Tiempo.ahora
  @update_mutex = Mutex (exclusión mutua).Nuevo
end

Detalles de atributo de instancias

#conexiónMongo::servidor::supervisar::Connection (solo lectura)

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Devuelve la conexión La conexión a utilizar.

Devuelve:

Desde:

  • 2.0.0



96
97
98
# Archivo 'lib/mongo/server/monitor.rb', línea 96

def Conexión
  @connection
end

#monitoringMonitoring (readonly)

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Supervisión de devoluciones La supervisión.

Devuelve:

Desde:

  • 2.0.0



118
119
120
# Archivo 'lib/mongo/server/monitor.rb', línea 118

def Monitoring
  @monitoring
end

#opcionesHash (solo lectura)

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Devuelve las opciones Opciones del servidor.

Devuelve:

  • (encriptada)

    options Las opciones del servidor.

Desde:

  • 2.0.0



99
100
101
# Archivo 'lib/mongo/server/monitor.rb', línea 99

def opciones
  @options
end

#servidorServidor (sólo lectura)

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Servidor de devoluciones El servidor que este supervisar está supervisando.

Devuelve:

  • (servidor)

    servidor El servidor que este monitor está supervisando.

Desde:

  • 2.0.0



93
94
95
# Archivo 'lib/mongo/server/monitor.rb', línea 93

def Server
  @server
end

Detalles del método de instancia

#create_push_monitor!(topology_version) ⇒ Object

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Desde:

  • 2.0.0



162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
# Archivo 'lib/mongo/server/monitor.rb', línea 162

def create_push_monitor!(topology_version)
  @update_mutex.sincronizar hacer
    @push_monitor = nulo si @push_monitor && !@push_monitor.¿corriendo?

    @push_monitor ||= PushMonitor.Nuevo(
      sí mismo,
      topology_version,
      Monitoring,
      **Utils.shallow_symbolize_keys(opciones.fusionar(
                                       socket_timeout: intervalo_latido + Conexión.socket_timeout,
                                       app_metadata: opciones[:push_monitor_app_metadata],
                                       check_document: @connection.check_document
                                     ))
    )
  end
end

#do_workobjeto

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Realiza una verificación del servidor.

Desde:

  • 2.0.0



131
132
133
134
135
136
137
138
139
140
141
142
143
# Archivo 'lib/mongo/server/monitor.rb', línea 131

def realizar_trabajo
  ¡escanear!
  # @next_wanted_scan puede ser actualizado por el monitor de push.
  # Sin embargo, debemos comprobar la bandera de terminación para que el monitor
  # El hilo se cierra cuando se solicita.
  bucle hacer
    delta = @next_wanted_scan - Tiempo.ahora
    break a menos que delta > 0

    señalado = Server.scan_semaphore.esperar(delta)
    break si señalado || @solicitud_detencion
  end
end

#heartbeat_intervalFloat

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

El intervalo entre comprobaciones regulares del servidor.

Devuelve:

  • (Float)

    El intervalo del latido, en segundos.

Desde:

  • 2.0.0



104
105
106
# Archivo 'lib/mongo/server/monitor.rb', línea 104

def intervalo_latido
  opciones[intervalo de latidos] || DEFAULT_HEARTBEAT_INTERVAL
end

#push_monitorServer::PushMonitor | nil

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Devuelve el monitor push, si se está utilizando uno.

Devuelve:

Desde:

  • 2.0.0



122
123
124
125
126
# Archivo 'lib/mongo/server/monitor.rb', línea 122

def push_monitor
  @update_mutex.sincronizar hacer
    @push_monitor
  end
end

#reinicio!Thread

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Reinicia el monitor del servidor a menos que el proceso actual esté todavía en ejecución.

Ejemplos:

Reinicia el monitor.

monitor.restart!

Devuelve:

  • (Thread)

    El hilo en el que se ejecuta el monitor.

Desde:

  • 2.1.0



257
258
259
260
261
262
263
# Archivo 'lib/mongo/server/monitor.rb', línea 257

def ¡reiniciar!
  si @thread && @thread.alive?
    @thread
  else
    ejecutar!
  end
end

#run_sdam_flow(result, awaited: false, scan_error: nil) ⇒ objeto

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Desde:

  • 2.0.0



223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
# Archivo 'lib/mongo/server/monitor.rb', línea 223

def run_sdam_flow(Resultado, esperado: false, scan_error: nulo)
  @sdam_mutex.sincronizar hacer
    old_description = Server.Descripción

    new_description = Descripción.Nuevo(
      Server.dirección,
      Resultado,
      average_round_trip_time: Server.calculadora_de_tiempo_de_viaje_redondo.average_round_trip_time,
      minimum_round_trip_time: Server.calculadora_de_tiempo_de_viaje_redondo.minimum_round_trip_time
    )

    Server.clúster.run_sdam_flow(Server.Descripción, new_description, esperado: en espera, scan_error: scan_error)

    Server.Descripción.tocar hacer |new_description|
      a menos que en espera
        si new_description.¿desconocido? && !old_description.¿desconocido?
          @next_earliest_scan = @next_wanted_scan = Tiempo.ahora
        else
          @next_earliest_scan = Tiempo.ahora + MIN_SCAN_INTERVAL
          @next_wanted_scan = Tiempo.ahora + intervalo_latido
        end
      end
    end
  end
end

#scan!Descripción

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Nota:

Si el reloj del sistema se atrasa, este método puede dormir durante mucho tiempo.

Nota:

El valor de retorno de este método está obsoleto. En la versión 3.0.0, este método no tendrá un valor de retorno.

Realice una comprobación del servidor con limitación y actualice la descripción del servidor y el tiempo medio de ida y vuelta.

Si se revisó el servidor hace menos de MIN_SCAN_INTERVAL segundos, se debe esperar hasta que hayan pasado MIN_SCAN_INTERVAL segundos desde la última revisión. A continuación, realiza la verificación que implica ejecutar hello en el servidor que se está supervisando y actualizar la descripción del servidor como resultado.

Devuelve:

Desde:

  • 2.0.0



206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
# Archivo 'lib/mongo/server/monitor.rb', línea 206

def ¡escanear!
  # Normalmente, el hilo en segundo plano invocaría este método.
  # Pero también es posible invocar scan! directamente sobre un monitor.
  # Permitir que solo se realice un escaneo a la vez.
  @mutex.sincronizar hacer
    throttle_scan_frequency!

    begin
      Resultado = do_scan
    rescate StandardError => e
      run_sdam_flow({}, scan_error: e)
    else
      run_sdam_flow(Resultado)
    end
  end
end

#¡stop!true | false

Detener el hilo en segundo plano y esperar a que finalice durante un tiempo razonable.

Devuelve:

  • (true | false)

    Si el hilo fue terminado.

Desde:

  • 2.0.0



151
152
153
154
155
156
157
158
159
160
# Archivo 'lib/mongo/server/monitor.rb', línea 151

def ¡detente!
  stop_push_monitor!

  # Reenviar el valor de retorno de super
  super.tocar hacer
    # Importante: la desconexión debería ocurrir después del hilo en segundo plano
    # termina.
    Conexión&.¡desconectar!
  end
end

#stop_push_monitor!objeto

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Desde:

  • 2.0.0



179
180
181
182
183
184
185
186
# Archivo 'lib/mongo/server/monitor.rb', línea 179

def stop_push_monitor!
  @update_mutex.sincronizar hacer
    si @push_monitor
      @push_monitor.¡detente!
      @push_monitor = nulo
    end
  end
end

#to_sObject

Este método es parte de una API privada. Se debe evitar el uso de este método si es posible, ya que podría eliminarse o modificarse en el futuro.

Desde:

  • 2.0.0



265
266
267
# Archivo 'lib/mongo/server/monitor.rb', línea 265

def to_s
  "#<#{self.clase.name}:#{object_id} #{servidor.address}>"
end