Você já se deparou com a frustrante mensagem "Socket Error Code: 10054" e se perguntou o que ela realmente significa?
Esse é um erro que pode surgir ao tentar estabelecer ou manter uma conexão de rede, indicando que a comunicação foi abruptamente encerrada pelo servidor
Se nenhuma das verificações apresentadas solucionar o problema, entre em contato com seu técnico de informática para que ele possa revisar e configurar a rede entre as máquinas. |
Quando a mensagem ocorre no terminal mas não no servidor, é fundamental verificar se as máquinas estão se comunicando adequadamente. Siga os passos abaixo para testar a conectividade:
Passo a passo:
1 - No Servidor:
2 - No Terminal:

Após executar o comando ping, observe o campo "Pacotes". Se a quantidade de pacotes enviados for igual à de pacotes recebidos (perdas = 0), significa que a comunicação entre o terminal e o servidor está ocorrendo corretamente. Caso contrário, a perda de pacotes indica problemas de conectividade.
Você pode realizar o mesmo teste do servidor para o terminal. Para isso, siga o processo inverso: copie o endereço IP do terminal e, no servidor, utilize o comando ping com o IP do terminal. |
Antes de fazer essa verificação é necessário confirmar se pode deixar o firewall das máquinas desativado. |
Passo a passo:



Verifique se o serviço do banco de dados está ativo. Se ele estiver parado, tanto o terminal quanto o servidor exibirão a mensagem de erro.
Passo a passo:


Se estiver em execução e o erro persistir, apenas reinicie o serviço.
O desempenho da máquina também pode interferir na execução do banco de dados. Confira se ela não está há muito tempo ligada em:
As máquinas podem não se comunicar caso a rede entre elas esteja bloqueada. Você pode verificar a existência de algum bloqueio em:

Autor do artigo: Rebarbosa.prime.shop (Não remova esse quadro)Descreva o passo a passo para o cliente seguindo os padrões de escrita de artigos, como:
|
(Não remova esse quadro)Essas informações não se tonam parte do conteúdo em sua nova página, elas ficam ocultas e só aprecem para usuário logado e se o artigo/dica estiver em modo de edição! |
<div id="text-end"></div>
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-193974933-1"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag2(){dataLayer.push(arguments);}
gtag2('js', new Date());
gtag2('config', 'UA-193974933-1');
function gtagevents (action,category) {
console.log(category + ':' + action);
gtag2('event',action,{event_category:category,event_label: document.title});
};
</script>
<script src="https://player.vimeo.com/api/player.js"></script>
<script>
(function(){
// RASTREIO DE USO DO VÍDEO
function gtagvideo(action){
gtagevents(action,'Video')
}
var iframe = document.querySelector('iframe');
var player = new Vimeo.Player(iframe);
var seeking = false;
var priorTime = 0;
var currentTime = 0;
var reportouFinalDoConteudo = false;
// se pausar o play é acionado também.
player.on('play', function(data) {
if(data.seconds == 0){
gtagvideo('video-iniciado');
}
priorTime = data.seconds;
});
player.on('ended', function() {
gtagvideo('video-finalizado');
});
//seeking e timeupdate são disparados juntos, logo o tempo dos 2 é atualizado também. Preciso garantir que a variavel starttime seja atualizada ordenadamente (sempre antes ou após o seeking).
// pra isso preciso setar uma variavel no timeupdate e ler no seeking para garantir a ordem. Se ela estiver false será alterada na próxima iteração.
player.on('seeking', function(data) {
seeking = true;
});
player.on('pause',function(data){
gtagvideo('video-pausado');
});
player.on('timeupdate', function(data) {
if(seeking){
if(currentTime < priorTime){
gtagvideo('video-voltando');
}
if(currentTime > priorTime){
gtagvideo('video-avancando')
}
seeking = false;
}
priorTime = currentTime;
currentTime = data.seconds;
var finalDoConteudo = (data.duration - data.seconds) < 5;
if(finalDoConteudo && !reportouFinalDoConteudo){
gtagvideo('conteudo-finalizado')
reportouFinalDoConteudo = true;
}
});
player.on('fullscreenchange', function() {
gtagvideo('video-fullscreen');
});
})();
</script>
<script>
// RASTREIO DO USO DE AUDIO
(function(){
function gtagaudio(action){
gtagevents(action,'Audio')
}
var audio = document.querySelector("audio");
var seeking = false;
var priorTime = 0;
var currentTime = 0;
audio.addEventListener('play',function(){
if(audio.currentTime == 0){
gtagaudio('audio-iniciado');
}
priorTime = audio.currentTime;
});
audio.addEventListener('ended',function(){
gtagaudio('audio-finalizado');
});
audio.addEventListener('pause',function(){
gtagaudio('audio-pausado');
});
audio.addEventListener('seeking', function(data) {
seeking = true;
});
audio.addEventListener('timeupdate', function(data) {
if(seeking){
if(currentTime < priorTime){
gtagaudio('audio-voltando');
}
if(currentTime > priorTime){
gtagaudio('audio-avancando')
}
seeking = false;
}
priorTime = currentTime;
currentTime = audio.currentTime;
});
})();
</script>
<script>
(function(){
var terminou = false;
//RASTREIO DE LEITURA ATÉ O FINAL DA PÁGINA
document.addEventListener('scroll',() => {
if(document.getElementById('text-end').getBoundingClientRect().top < window.innerHeight){
if(!terminou){
terminou = true;
gtagevents('artigo-lido','Pagina')
}
}else{
terminou = false;
}
});
})();
</script>
|