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- 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- 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
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 .
76 77 78 79 80 81 82 83 84 85 86 87 88 89 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 76 def inicializar(Servidor, event_listeners, Monitoramento, = {}) aumentar ArgumentError, "Tipo de monitoramento incorreto: #{monitoring.inspect}" a menos que Monitoramento.is_a?(Monitoramento) aumentar ArgumentError, ' Osmetadados do aplicativo são obrigatórios' a menos que [:app_metadata] aumentar ArgumentError, ' Osmetadados do aplicativo de monitoramento são necessários' a menos que [:push_monitor_app_metadata] @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.
96 97 98 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 96 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.
118 119 120 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 118 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 .
99 100 101 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 99 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.
93 94 95 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 93 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.
162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 162 def create_push_monitor!(topology_version) @update_mutex.sincronizar fazer @push_monitor = nada se @push_monitor && !@push_monitor.executando? @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.
131 132 133 134 135 136 137 138 139 140 141 142 143 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 131 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 intervalo a menos que delta, delta > 0 sinalizado = Servidor.varredura_semafore.esperar(delta, delta) intervalo se sinalizado || @stop_requested 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 .
104 105 106 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 104 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.
122 123 124 125 126 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 122 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.
257 258 259 260 261 262 263 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 257 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.
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 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 223 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.
206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 206 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 StandardError => 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.
151 152 153 154 155 156 157 158 159 160 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 151 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.
179 180 181 182 183 184 185 186 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 179 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.
265 266 267 |
# Arquivo 'lib/mongo/ servidor/monitor.rb', linha 265 def to_s "#<#{self.classe.name}:#{object_id} #{servidor.endereço}>" end |