Classe: Mongo::Servidor::Monitor Privado
- Herda:
-
Objeto
- Objeto
- Mongo::Servidor::Monitor
- Estendido por:
- Encaminhável
- Inclui:
- BackgroundThread, Evento::editor, Loggable
- Definido em:
- lib/mongo/ servidor/monitor.rb,
lib/mongo/ servidor/monitor/connection.rb,
lib/mongo/ servidor/monitor/app_metadata.rb
Visão geral
Esta classe faz parte de uma API privada. Evite usar essa classe, se possível, pois ela pode ser removida ou alterada no futuro.
Responsáveis por pesquisar periodicamente um servidor por meio de comandos hello para manter o status do servidor atualizado.
Tudo funciona em um thread em background para não interferir em outras operações realizadas pelo driver.
Definido sob namespace
Classes: AppMetadata, Conexão
Colapsode resumo constante
- DEFAULT_HEARTBEAD_INTERVAL =
Essa constante faz parte de uma API privada. Você deve evitar usar essa constante, se possível, pois ela pode ser removida ou alterada no futuro.
O intervalo padrão entre as atualizações de status do servidor é de 10 segundos.
10.congelar
- MIN_SCAN_INTERVAL =
Essa constante faz parte de uma API privada. Você deve evitar usar essa constante, se possível, pois ela pode ser removida ou alterada no futuro.
O tempo mínimo entre as verificações forçadas do servidor . É minHeartbeatFrequencyMS na especificação SDAM.
0.5.congelar
- RTT_WEight_FACTOR =
Essa constante faz parte de uma API privada. Você deve evitar usar essa constante, se possível, pois ela pode ser removida ou alterada no futuro.
Obsoleto.Será removido na versão 3.0.
O fator de ponderação (alfa) para calcular o tempo médio de ida e volta em movimento.
0.2.congelar
Constantes incluídas do Loggable
Recolhimento do Resumo do atributo de instância
-
#connection ➤ Mongo::Server::Monitor::Connection
Somente leitura
privado
Conexão A conexão a ser usada.
-
#monitoramento ➤ Monitoramento
Somente leitura
privado
Monitoramento O monitoramento.
-
#opções ➤ Hash
Somente leitura
privado
Opções As opções do servidor .
-
#server ⇒ Server
Somente leitura
privado
Servidor MongoDB O servidor que este monitor está monitorando.
Atributos incluídos do Evento::editor
Recolhimento do Resumo do método de instância
- #create_push_monitor!(topology_version) ➤ Objeto privado
-
#do_work ➤ Objeto
privado
Execute uma verificação do servidor.
-
#heartbeat_interval ➤ Flutuante
privado
O intervalo entre verificações regulares do servidor .
-
#initialize(servidor, event_listeners, monitoramento, opções = {}) ➤ Monitorar
construtor
privado
Crie o novo monitor de servidor .
-
#push_monitor ➤ Servidor::PushMonitor | nada
privado
O monitor de push, se houver um sendo usado.
-
#reiniciar! ➤ Thread
privado
Reinicia o monitor do servidor , a menos que o thread atual esteja vivo.
- #run_sdam_flow(result, awaited: false, varredura_error: nil) ⇒ Object privado
-
#scan! ➤ Descrição
privado
Execute uma verificação do servidor com limitação e atualize a descrição do servidor e o tempo médio de ida e volta.
-
#pare! ➤ verdadeiro | false
Interrompa o thread em background e aguarde até que ele encerre por um período de tempo razoável.
- #stop_push_monitor! ➤ Objeto privado
- #to_s ➤ Objeto privado
Métodos incluídos do BackgroundThread
Métodos incluídos no Loggable
#log_debug, #log_error, #log_fatal, #log_info, #log_WARN, #logger
Métodos incluídos do Event::publisher
Detalhes do construtor
#initialize(servidor, event_listeners, monitoramento, opções = {}) ➤ Monitorar
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
O Monitor nunca deve ser diretamente instanciado fora de um Servidor.
Crie o novo monitor de servidor .
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 78 def inicializar(Servidor, event_listeners, Monitoramento, = {}) a menos que Monitoramento.is_a?(Monitoramento) aumentar ArgumentError, "Tipo de monitoramento incorreto: #{monitoring.inspect}" end a menos que [:app_metadata] aumentar ArgumentError, ' Osmetadados do aplicativo são obrigatórios' end a menos que [:push_monitor_app_metadata] aumentar ArgumentError, ' Osmetadados do aplicativo de monitoramento são necessários' end @server = Servidor @event_listeners = event_listeners @monitoring = Monitoramento @opções = .congelar @mutex = Mutex.Novo @sdam_mutex = Mutex.Novo @next_earlyest_scan = @next_Quered_scan = Hora.agora @update_mutex = Mutex.Novo end |
Detalhes do atributo da instância
#connection ➤ Mongo::Server::Monitor::Connection (somente leitura)
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Retorna a conexão A conexão a ser usada.
103 104 105 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 103 def Conexão @connection end |
#Monitoring ➤ Monitoramento (somente leitura)
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Monitoramento de retornos O monitoramento.
125 126 127 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 125 def Monitoramento @monitoring end |
#opções ➤ Hash (somente leitura)
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Retorna opções As opções do servidor .
106 107 108 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 106 def @opções end |
#servidor ➤ Servidor (somente leitura)
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Retorna servidor O servidor que este monitor está monitorando.
100 101 102 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 100 def Servidor @server end |
Detalhes do método de instância
#create_push_monitor!(topology_version) ➤ Objeto
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 173 def create_push_monitor!(topology_version) @update_mutex.sincronizar fazer se @push_monitor && !@push_monitor.executando? @push_monitor = nada end @push_monitor ||= PushMonitor.Novo( auto, topology_version, Monitoramento, **Utilidades.raso_symbolize_keys(.mesclar( socket_timeout: heartbeat_interval + Conexão.socket_timeout, app_metadata: [:push_monitor_app_metadata], check_document: @connection.check_document )), ) end end |
#do_work ➤ Objeto
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Execute uma verificação do servidor.
138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 138 def do_work digitalizar! # @next_Quered_scan pode ser atualizado pelo monitor de push. # No entanto, precisamos verificar se há sinalizador de encerramento para que o monitor # thread é encerrado quando solicitado. loop fazer delta, delta = @next_Quered_scan - Hora.agora se delta, delta > 0 sinalizado = Servidor.varredura_semafore.esperar(delta, delta) se sinalizado || @stop_requested intervalo end mais intervalo end end end |
#heartbeat_interval ➤ Flutuante
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
O intervalo entre verificações regulares do servidor .
111 112 113 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 111 def heartbeat_interval [: heartbeat_interval] || DEFAULT_HEARTBEAD_INTERVAL end |
#push_monitor ➤ Servidor::PushMonitor | nada
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Retorna o monitor de push, se houver um sendo usado.
129 130 131 132 133 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 129 def push_monitor @update_mutex.sincronizar fazer @push_monitor end end |
#reiniciar! ➤ Thread
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Reinicia o monitor do servidor , a menos que o thread atual esteja vivo.
270 271 272 273 274 275 276 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 270 def reinicie! se @thread && @thread.alive? @thread mais corra! end end |
#run_sdam_flow(result, awaited: false, varredura_error: nil) ⇒ Object
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no 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 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 236 def run_sdam_flow(Resultado, esperado: false, varredura_error: nada) @sdam_mutex.sincronizar fazer old_description = Servidor.Descrição new_description = Descrição.Novo( Servidor.endereço, Resultado, average_round_trip_time: Servidor.round_trip_time_calculator.average_round_trip_time, minimum_round_trip_time: Servidor.round_trip_time_calculator.minimum_round_trip_time ) Servidor.cluster.run_sdam_flow(Servidor.Descrição, new_description, esperado: esperado, varredura_error: varredura_error) Servidor.Descrição.toque fazer |new_description| a menos que esperado se new_description.desconhecido? && !old_description.desconhecido? @next_earlyest_scan = @next_Quered_scan = Hora.agora mais @next_earlyest_scan = Hora.agora + MIN_SCAN_INTERVAL @next_Quered_scan = Hora.agora + heartbeat_interval end end end end end |
#scan! ➤ Descrição
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
Se o relógio do sistema se mover para trás, esse método poderá adormecido por um longo tempo.
O valor de retorno deste método é preterido. Na versão 3.0.0 , este método não terá um valor de retorno.
Execute uma verificação do servidor com limitação e atualize a descrição do servidor e o tempo médio de ida e volta.
Se o servidor foi verificado há menos de MIN_SCAN_INTERVAL segundos, durma até que MIN_SCAN_INTERVAL segundos tenham se passado desde a última verificação. Em seguida, execute a verificação que envolve executar hello no servidor que está sendo monitorado e atualizar a descrição do servidor como resultado.
219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 219 def digitalizar! # Normalmente, o thread do background invocaria esse método. # Mas também é possível invocar varredura! diretamente em um monitor. # Permitir que apenas uma verificação seja realizada de cada vez. @mutex.sincronizar fazer acelerador_scan_frequency! começar Resultado = do_scan salvar => e run_sdam_flow({}, varredura_error: e) mais run_sdam_flow(Resultado) end end end |
#pare! ➤ verdadeiro | false
Interrompa o thread em background e aguarde até que ele encerre por um período de tempo razoável.
162 163 164 165 166 167 168 169 170 171 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 162 def pare! stop_push_monitor! # Encaminhar valor de retorno de super super.toque fazer # Importante: a desconexão deve ocorrer após a thread no background # termina. Conexão&.desconecte-se! end end |
#stop_push_monitor! ➤ Objeto
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
192 193 194 195 196 197 198 199 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 192 def stop_push_monitor! @update_mutex.sincronizar fazer se @push_monitor @push_monitor.pare! @push_monitor = nada end end end |
#to_s ➤ Objeto
Este método faz parte de uma API privada. Evite usar esse método, se possível, pois ele pode ser removido ou alterado no futuro.
278 279 280 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 278 def to_s "#<#{self.classe.name}:#{object_id} #{servidor.endereço}>" end |