AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1426652
Accepted
RichardB
RichardB
Asked: 2019-04-18 09:45:50 +0800 CST2019-04-18 09:45:50 +0800 CST 2019-04-18 09:45:50 +0800 CST

Erro de conexão TCP intermitente do MSSQL em consultas de alta frequência ao servidor vinculado (relacionado ao pool de conexões?)

  • 772

Tenho quatro trabalhos do SQL Agent em execução contínua. Cada trabalho está executando um procedimento armazenado que consulta transações ATM recentes, tudo por meio do mesmo servidor vinculado. Isso acontece em um loop dentro de cada trabalho com um atraso de 5 segundos entre as execuções do proc (usando WAITFOR DELAY).

Especificamente, um dos quatro trabalhos está usando um procedimento armazenado e os outros três estão usando outro. Cada execução de trabalho tem seu próprio conjunto de parâmetros relacionados a padrões específicos de transações que acionarão uma resposta. Eles estão todos consultando o mesmo servidor vinculado.

Na maioria das vezes, tudo está funcionando bem. Mas ocasionalmente (quase *) qualquer um dos trabalhos falhará com este erro:

Provedor TCP: o nome de rede especificado não está mais disponível. [SQLSTATE 42000] (Erro 64) O provedor OLE DB "SQLNCLI11" para o servidor vinculado "ATMDB" retornou a mensagem "Falha no link de comunicação". [SQLSTATE 01000] (Erro 7412).

Isso só começou a acontecer depois que os trabalhos foram atualizados para serem executados continuamente com o loop WAITFOR, em vez de serem executados uma vez a cada minuto como uma execução de trabalho separada do SQL Agent. Essa alteração foi feita para evitar o registro excessivo de tarefas SQL e também para monitorar as transações do caixa eletrônico muito mais próximo do tempo real.

Não há consistência com a frequência com que eles falharão, mas é pelo menos algumas vezes ao dia.

*Eu digo "quase" acima, porque um dos trabalhos nunca falhou. Este é o que mais recebe "acertos" e, quando isso ocorre, a etapa do trabalho pode ser concluída, portanto, temos um registro explícito disso nos logs do trabalho SQL. (Em seguida, volta para a primeira etapa novamente após um atraso de 1 segundo.)

Todos os trabalhos são configurados para serem executados a cada minuto. Portanto, após uma falha, o trabalho será reiniciado no início do próximo minuto, portanto, isso não está afetando muito as coisas. É muito chato!

Suspeito que o SQL Native Client e como ele implementa o pool de conexões seja a raiz do problema. Durante o teste, atualizei o servidor vinculado em um dos dois procedimentos para ser diferente do outro. Dois nomes de host diferentes, mas ainda o mesmo servidor (só usei o arquivo hosts para criar um novo nome). Isso fazia com que um trabalho não falhasse mais, mas dois dos três outros trabalhos ainda falhavam intermitentemente. Depois de alternar o outro procedimento para também usar o mesmo servidor vinculado novamente, agora todos os trabalhos novamente falhariam ocasionalmente. Como os pools de conexão são específicos para a string de conexão, um nome de servidor diferente faria com que um pool diferente fosse usado.

Usando o monitor de recursos do Windows, posso ver que geralmente há três conexões TCP abertas para o servidor vinculado. Eles permanecem abertos nas mesmas portas por vários minutos, então acho que está usando algum tipo de pool de conexão. Quando o erro acontece, ele coincide com o fechamento de uma das conexões e logo em seguida uma nova conexão será aberta.

Minha teoria atual: como os processos estão em loop repetidamente durante o uso do servidor vinculado, algo no pool de conexões causa uma situação em que ele está tentando usar uma conexão que foi fechada por qualquer motivo. Talvez a única etapa do trabalho que "conclua" de vez em quando seja atualizada de alguma forma e evite que o erro ocorra nesse processo específico.

Tentei envolver as chamadas de procedimento armazenado em sp_executesql como uma solução alternativa para "forçar" outro processo ou contexto de execução, mas isso não ajudou.

Ambos os servidores são Windows 2012, rodando em VMWare.

Alguma idéia sobre como solucionar problemas adicionais?

tcp sql-server remote-connection
  • 1 1 respostas
  • 800 Views

1 respostas

  • Voted
  1. Best Answer
    RichardB
    2019-07-17T12:41:23+08:002019-07-17T12:41:23+08:00

    O problema foi resolvido depois que os hosts da VM foram substituídos por um hardware mais recente. Isso sugere que foi um problema de nível de rede/hardware, e não algo devido à maneira específica como as consultas foram programadas ou como o SQL está configurado.

    • 0

relate perguntas

  • O cliente não está respondendo ao driver ethernet do pacote TCP SYN-ACK

  • Migrando windows server 2008

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    Serviço do Windows 10 chamado AarSvc_70f961. O que é e como posso desativá-lo?

    • 2 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Marko Smith

    ssl.SSLCertVerificationError: falha na verificação do certificado [SSL: CERTIFICATE_VERIFY_FAILED]: não foi possível obter o certificado do emissor local (_ssl.c:1056)

    • 4 respostas
  • Marko Smith

    Como posso saber em qual unidade o Windows está instalado?

    • 6 respostas
  • Martin Hope
    Albin Como faço para ativar o WindowsXP agora que o suporte acabou? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch O Windows 10 exclui muitos arquivos minúsculos muito lentamente. Algo pode ser feito para agilizar? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Como Ctrl+C e Ctrl+V funcionam? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve