Clase: Mongo::Server::Monitor Privado
- Hereda:
-
Objeto
- Objeto
- Mongo::servidor::Monitor
- 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 sondear periódicamente un servidor a través de comandos hello para mantener el estado del servidor actualizado.
Realiza todo el trabajo en un hilo en segundo plano para no interferir con otras operaciones realizadas por el driver.
Definido bajo Namespace
Clases: AppMetadata, Conexión
Colapso delresumen constante
- DEFAULT_HEARTBEAT_INTERVAL =
Esta constante forma parte de una API privada. Debe evitar usarla siempre que sea posible, ya que podría eliminarse o modificarse en el futuro.
El intervalo por defecto entre actualizaciones del estado del servidor es de 10 segundos.
10.freeze
- MIN_SCAN_INTERVAL =
Esta constante forma parte de una API privada. Debe evitar usarla siempre que sea posible, ya que podría eliminarse o modificarse en el futuro.
El tiempo mínimo entre escaneos forzados del servidor. minHeartbeatFrequencyMS en la especificación SDAM.
0.5.freeze
- RTT_WEIGHT_FACTOR =
Esta constante forma parte de una API privada. Debe evitar usarla siempre que sea posible, ya que podría eliminarse o modificarse 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.
0.2.freeze
Constantes incluidas desde Loggable
Resumen de atributos de la instancia colapsar
-
#connection ⇒ Mongo::servidor::supervisar::Connection
Solo lectura
privado
Conexión La conexión que se va a usar.
-
#monitoring ⇒ Monitoring
Solo lectura
privado
Supervisión La supervisión.
-
#options ⇒ Hash
Solo lectura
privado
Opciones Las opciones del servidor.
-
#server ⇒ Server
Solo lectura
privado
Servidor El servidor que este monitor está monitoreando.
Atributos incluidos de Event::Publisher
Resumen del método de instancia colapsar
- #create_push_monitor!(topology_version) ⇒ Object privado
-
#do_work ⇒ Objeto
privado
Realiza una verificación del servidor.
-
#heartbeat_interval ⇒ Float
privado
El intervalo entre comprobaciones regulares del servidor.
-
#inicializar(servidor, event_listeners, supervisión, opciones = {}) ⇒ Supervisar
constructor
privado
Cree el nuevo monitor de servidor.
-
#push_monitor ⇒ Server::PushMonitor | nil
privado
El monitor de empuje, si se está utilizando uno.
-
#¡reinicia! ⇒ Hilo
privado
Reinicia el monitor del servidor a menos que el proceso actual esté todavía en ejecución.
- #run_sdam_flow(result, aguardado: false, scan_error: nil) ⇒ objeto privado
-
#¡escanear! ⇒ Descripción
privado
Realice una verificación del servidor con limitación y actualice la descripción del servidor y el tiempo de ida y vuelta promedio.
-
#¡Alto! ⇒ verdadero | falso
Detener el hilo en segundo plano y esperar a que finalice durante un tiempo razonable.
- #stop_push_monitor! ⇒ objeto privado
- #to_s ⇒ Objeto privado
Métodos incluidos desde BackgroundThread
Métodos incluidos desde Registrable
#log_debug, #log_error, #log_fatal, #log_info, #log_warn, #logger
Métodos incluidos desde Event::Publisher
Detalles del constructor
#inicializar(servidor, listeners_de_eventos, supervisión, opciones = {}) ⇒ Monitor
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
El monitor nunca debe ser instanciado directamente fuera de un servidor.
Cree el nuevo monitor de servidor.
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# Archivo 'lib/mongo/server/monitor.rb', línea 78 def inicializar(Server, event_listeners, Monitoring, = {}) a menos que Monitoring.is_a?(Monitoring) propagar ArgumentError, "Tipo de supervisión incorrecto: #{supervisión.inspect}" end a menos que [:app_metadata] propagar ArgumentError, 'Los metadatos de la aplicación son obligatorios' end a menos que [:push_monitor_app_metadata] propagar ArgumentError, 'Serequieren metadatos de la aplicación Push Monitor' end @server = Server @event_listeners = event_listeners @monitoring = Monitoring @options = .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 los atributos de instancia
#conexión ⇒ Mongo::servidor::supervisar::Connection (solo lectura)
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Devuelve la conexión La conexión a utilizar.
103 104 105 |
# Archivo 'lib/mongo/server/monitor.rb', línea 103 def Conexión @conexión end |
#monitoring ⇒ Monitoring (readonly)
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Supervisión de devoluciones La supervisión.
125 126 127 |
# Archivo 'lib/mongo/server/monitor.rb', línea 125 def Monitoring @monitoring end |
#opciones ⇒ Hash (solo lectura)
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Devuelve las opciones Opciones del servidor.
106 107 108 |
# Archivo 'lib/mongo/server/monitor.rb', línea 106 def @options end |
#servidor ⇒ Servidor (sólo lectura)
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Servidor de devoluciones El servidor que este supervisar está supervisando.
100 101 102 |
# Archivo 'lib/mongo/server/monitor.rb', línea 100 def Server @server end |
Detalles del método de instancia
#create_push_monitor!(versión_de_topología) ⇒ Objeto
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 |
# Archivo 'lib/mongo/server/monitor.rb', línea 173 def ¡crear_monitor_push!(topology_version) @update_mutex.sincronizar hacer si @push_monitor && !@push_monitor.¿correr? @push_monitor = nulo end @push_monitor ||= Monitor de empuje.Nuevo( sí mismo, topology_version, Monitoring, **Utils.shallow_symbolize_keys(.fusionar( socket_timeout: intervalo_latido + Conexión.socket_timeout, app_metadata: [:push_monitor_app_metadata], check_document: @conexión.check_document )), ) end end |
#do_work ⇒ objeto
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Realiza una verificación del servidor.
138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 |
# Archivo 'lib/mongo/server/monitor.rb', línea 138 def realizar_trabajo ¡escanear! # @next_wanted_scan puede ser actualizado por el monitor push. # Sin embargo, debemos verificar el indicador de terminación para que el monitor # El hilo se cierra cuando se solicita. bucle hacer delta = @next_wanted_scan - Tiempo.ahora si delta > 0 señalado = Server.semáforo de escaneo.esperar(delta) si señalado || @solicitud_detencion break end else break end end end |
#heartbeat_interval ⇒ Float
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
El intervalo entre comprobaciones regulares del servidor.
111 112 113 |
# Archivo 'lib/mongo/server/monitor.rb', línea 111 def intervalo_latido [:intervalo_de_latidos] || DEFAULT_HEARTBEAT_INTERVAL end |
#push_monitor ⇒ Server::PushMonitor | nil
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Devuelve el monitor push, si se está utilizando uno.
129 130 131 132 133 |
# Archivo 'lib/mongo/server/monitor.rb', línea 129 def monitor_push @update_mutex.sincronizar hacer @push_monitor end end |
#¡reinicia! ⇒ Hilo
Este método forma parte de una API privada. Debe evitarlo 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.
270 271 272 273 274 275 276 |
# Archivo 'lib/mongo/server/monitor.rb', línea 270 def ¡reiniciar! si @thread && @thread.alive? @thread else ejecutar! end end |
#run_sdam_flow(result, awaited: false, scan_error: nil) ⇒ objeto
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 |
# Archivo 'lib/mongo/server/monitor.rb', línea 236 def run_sdam_flow(Resultado, esperado: false, error de escaneo: nulo) @sdam_mutex.sincronizar hacer old_description = Server.Descripción new_description = Descripción.Nuevo( Server.dirección, Resultado, tiempo promedio de ida y vuelta: Server.calculadora_de_tiempo_de_viaje_redondo.average_round_trip_time, minimum_round_trip_time: Server.calculadora_de_tiempo_de_viaje_redondo.tiempo mínimo de ida y vuelta ) Server.clúster.run_sdam_flow(Server.Descripción, new_description, esperado: en espera, error de escaneo: 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 forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Si el reloj del sistema se retrasa, este método puede permanecer inactivo durante mucho tiempo.
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 verificación del servidor con limitación y actualice la descripción del servidor y el tiempo de ida y vuelta promedio.
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.
219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 |
# Archivo 'lib/mongo/server/monitor.rb', línea 219 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 => e run_sdam_flow({}, error de escaneo: 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.
162 163 164 165 166 167 168 169 170 171 |
# Archivo 'lib/mongo/server/monitor.rb', línea 162 def ¡detener! 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 forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
192 193 194 195 196 197 198 199 |
# Archivo 'lib/mongo/server/monitor.rb', línea 192 def stop_push_monitor! @update_mutex.sincronizar hacer si @push_monitor @push_monitor.¡detener! @push_monitor = nulo end end end |
#to_s ⇒ Object
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
278 279 280 |
# Archivo 'lib/mongo/server/monitor.rb', línea 278 def to_s "#<#{self.clase.name}:#{object_id} #{servidor.address}>" end |