Opção De Tubo Quebrado Java.net.socketception
August 19, 2021Recomendado: Fortect
Durante a semana passada, alguns parecidos com nossos leitores encontraram um código de erro violado do canal java.net.socketexception. Essa complicação pode surgir por vários motivos. Nós os cobriremos abaixo.
- é principalmente elaborado para unir quando a natureza, que tem a ver com a outra extremidade, já o fez;
- com menos frequência – um parceiro importante que fecha o relatório sem ter lido todos os dados que já estavam aguardando processamento na última parte.
Em ambos os casos, você possui um novo protocolo que é um site definido ou aplicado pelo utilitário.
Há uma terceira justificativa de que não vou documentar, lembre-se, porém, aqui eu sei que a outra metade tem o hobby consciente de redefinir a conexão em vez de fechá-la corretamente.
escolha em 22 de fevereiro de 10 próximo às 9h13
292k
Em nosso caso, todos notaram isso quando executamos um novo teste de carga em nossa loja online de aplicativos. Ok. Acontece que nosso número precisava adicionar RAM extra para nosso JVM porque ele é executado. Isso resolveu a maior parte do problema.
Tente aumentar a quantidade de memória disponível na JVM ou talvez até mesmo monitore o uso geral da memória em caso de erros.
126k 8282 emblemas de relógio indesejados
respondeu em 15 de agosto de 2012 às 13h30, horário de Moscou.
Recomendado: Fortect
Você está cansado de ver seu computador lento? Está cheio de vírus e malware? Não tema, meu amigo, pois Fortect está aqui para salvar o dia! Esta poderosa ferramenta foi projetada para diagnosticar e reparar todos os tipos de problemas do Windows, ao mesmo tempo em que aumenta o desempenho, otimiza a memória e mantém seu PC funcionando como novo. Então não espere mais - baixe o Fortect hoje mesmo!
417
SocketException: Broken Pipe, elementos apenas a “outra extremidade” (cliente servidor) para fechar a conexão enquanto seu código lê ou grava qualquer coisa na conexão.
Essa será uma exceção muito comum sempre que você estiver usando o gerenciamento de aplicativos cliente-servidor que recebem tráfego de proprietários ou servidores fora do aplicativo para remoção. Por exemplo, todo cliente é definitivamente um navegador. Se o navegador fizer um Ajax falar com e / ou o PC founder apenas fechar a página ou uma determinada Internet, ele pode encerrar todas as proteções inesperadamente. Basicamente, você pode ver este excelente erro toda vez que o cartório do usuário sela seu pedido e não pensou em fazê-lo.
Se alguém souber como essa exceção funciona para o seu aplicativo, talvez você precise verificar o código correto no qual, por sua vez, o código de E / S (I ou O) está sendo executado e até mesmo encerrá-lo com um disco rígido bloco get / catch para capturar a exceção de ideia de entrada-saída. É então para cima para você como você quiser que superará esta situação semiválida.
No seu caso, você geralmente tem controle inicial específico sobre a chamada, o que ajuda você com HttpMethodDirector.executeWithRetry
– portanto, certifique-se de que o contato seja coberto com um bloco de tentativa por captura para ter mais operação isto. você analisa, o problema se encaixa.
Eu recomendo fortemente transportar erros específicos de SocketException – Broken Pipe em níveis incomuns, como Debug / Trace. Caso contrário, pode ser usado como a forma mais recente de ataque de negação de serviço (DOS) e para popular os logs. Tente endurecer e testar negativamente sua aplicação pessoal para eliminar essas condições comuns.
respondeu 12 fev 18:02
227
Todos os canais e conexões abertos devem tentar ser desabilitados adequadamente para que este recurso não gere um erro na próxima vez que você testar usando a maior parte do objeto urlConnection. Por exemplo, o código essencial corrigiu o erro para mim.
OutputStream outdoor = inovador novo BufferedOutputStream (urlConnection.getOutputStream ());BufferedWriter bw = BufferedWriter (novo OutputStreamWriter (saída));bw.write ("Algum texto");bw.close ();out.close ();
Sistema operacional OutputStream é igual a urlConnection.getOutputStream ();OutputStream out = BufferedOutputStream (OS) original;BufferedWriter bw é igual a new BufferedWriter (new OutputStreamWriter (out));bw.write ("Algum texto");bw.close ();out.close ();os.close (); // É necessário.
tornou-se uma resposta em dezoito de setembro, 12 às 9h01
Eu tive o mesmo problema ao iniciar um aplicativo Java simples que os agentes dizem em um TCP específico a grande maioria. Normalmente não tive problemas, embora sempre que execute um teste de incômodo, veja os erros de conexão com um erro de diferença de gravação de soquete
.
Depois de pesquisar, encontrei uma solução que resolve esse tipo de pequeno problema. Sei que esta especulação pode ser bastante antiga, mas prefiro compartilhar minha solução, outra mulher pode achar útil.
O problema estava criando o ServerSocket. Eu li no Javadoc que recentemente há um limite padrão de 200 soquetes de espera. Se você tentar quando precisar desconectar outra conexão, ela será particularmente perdida. A solução Consist, por sua vez, fornece esta configuração. A configuração padrão é considerada no nível do servidor. No seguinte caso de uma pessoa, estou desenvolvendo um servidor de socket específico que escuta cuidadosamente a porta TCP 10_000
ou aceita Sloth 400
sockets pendentes.
novo relógio (() -> investigar (ServerSocket serverSocket = ServerSocket (10_000, progressivo 200)) logger.info ("Servidor cria escuta na porta TCP", porta); para a duração (verdadeiro) teste ClientHandler clienthandler = clientHandlerProvider.getObject (serverSocket.accept (), this); executeor.execute (clientHandler :: start); captura (exceção e) logger.error (por exemplo, getmessage ()); hit (IOException) .start ();
T
Baixe este software e conserte seu PC em minutos.Primeiro, certifique-se de que o computador remoto esteja executando o Telnet em qualquer transporte