Решение для сломанной трубы Java.net.socketception
August 19, 2021Рекомендуется: Fortect
Фактически за последнюю неделю некоторые из наших потенциальных клиентов столкнулись с неработающим кодом ошибки java.net.socketexception туннеля. Эта проблема может выйти на первый план по нескольким причинам. Мы раскроем его или ее ниже.
- в основном написано о подписке, когда природа другого конца уже запечатлела это;
- очень часто – партнер, что люди закрывают отчет, не прочитав более-менее все данные, которые уже ждут обработки в конце.
В обоих случаях у вас есть современный протокол, который плохо определен и применяется приложением.
Есть третья причина, по которой я не буду документировать, но я знаю, что у партнера есть сознательное хобби сбросить аффилированность, а не полностью закрыть соединение.
решила высоко 22 февраля 10 в 9:13
292k
В нашем случае мы заметили это, когда запустили исследование нагрузки на сайте нашего приложения. Хорошо, это изменило то, что требовалось нашей команде, чтобы добавить дополнительную оперативную память в нашу JVM, потому что она заканчивается. Это решило большинство проблем.
Попробуйте увеличить объем доступной памяти на JVM или проследите за общим использованием памяти в случае возникновения ошибок.
126k
ответил 15 августа наступающего года в 13:30 мск.
Рекомендуется: Fortect
Вы устали от медленной работы компьютера? Он пронизан вирусами и вредоносными программами? Не бойся, друг мой, Fortect здесь, чтобы спасти положение! Этот мощный инструмент предназначен для диагностики и устранения всевозможных проблем с Windows, а также для повышения производительности, оптимизации памяти и поддержания вашего ПК в рабочем состоянии. Так что не ждите больше - скачайте Fortect сегодня!
а>
417
SocketException: Broken Pipe, заставляет только один «другой конец» (клиент и сервер) убедиться, что вы закрываете соединение, пока ваши рекомендации читают или записывают все в его соединение.
Это действительно довольно частое исключение при использовании планов клиент-сервер для управления, которые получают трафик от владельцев, возможно, серверов вне приложения для удаления. Например, клиент определенно может быть браузером. Если посетитель выполняет вызов Ajax и / или оператор ПК просто завершает страницу или Интернет, этот метод может неожиданно завершить работу всех адресов. По сути, вы можете видеть эту ошибку каждый раз, когда пользователь закрывает свое компьютерное программное обеспечение и не планировал этого делать.
Если вы знаете, как это исключение работает в вашем пакете, вам может потребоваться проверить, я бы сказал, правильный код, в котором выполняется правило ввода-вывода (I / O), и завершить работу информационных технологий с помощью жесткой попытки / см. блок, чтобы поймать это исключение ввода-вывода. Тогда действительно вам решать, как вы хотите преодолеть эту полу-валидную ситуацию.
На вашем месте у вас часто есть самый ранний обработчик вызова, который помогает кому-то с HttpMethodDirector.executeWithRetry
– теперь убедитесь, что вызов покрыт препятствием try / catch, чтобы иметь больший контроль над один. вы анализируете, это подходит.
Я настоятельно рекомендую регистрировать конкретные ошибки SocketException – Broken Pipe на разных уровнях, похожих на Debug / Trace. В противном случае его можно было бы использовать как форму атаки отказа в обслуживании (DOS) и, следовательно, для заполнения журналов. Постарайтесь укрепить и отрицательно протестировать свое приложение, чтобы исключить этот распространенный сценарий.
ответ дан 14 фев 18:02
227 22 коллекционных серебряных значка
Все открытые программы и соединения должны быть правильно неумелыми, чтобы этот инструмент не генерировал ошибку в следующий момент, когда вы тестируете с помощью объекта urlConnection. Например, следующий код ошибки для меня.
OutputStream outdoor = новый BufferedOutputStream (urlConnection.getOutputStream ());BufferedWriter bw = BufferedWriter (новые виды OutputStreamWriter (вывод));bw.write («Какой-то текст»);bw.close ();out.close ();
OutputStream os приводит к urlConnection.getOutputStream ();OutputStream out = новый BufferedOutputStream (ОС);BufferedWriter bw равен new BufferedWriter (new OutputStreamWriter (out));bw.write («Какой-то текст»);bw.close ();out.close ();os.close (); // Это просто необходимо.
получил абсолютный ответ 14 сентября, 12 с 9:01.
У меня, несомненно, была та же проблема при разработке простого и легкого Java-приложения, которое больше всего шпионит за конкретным TCP. Обычно у меня не возникало проблем, но при каждом запуске стресс-теста соединение разрывается с единственной ошибкой Socket write exception
.
После исследования я нашел идеальное решение для этого небольшого сценария. Я знаю, что этот вопрос может стать довольно старым, но я предпочитаю помочь поделиться своим решением, кто-то может счесть его полезным.
Проблема заключалась в создании ServerSocket. Я читал во время Javadoc, что есть одно конкретное ограничение по умолчанию в 150 ожидающих электрических розеток. Если вы попытаетесь отключить другие соединения, оно будет потеряно. Решение Consist, в свою очередь, имеет это в свою очередь config. По умолчанию это точно на уровне сервера. По правде говоря, я разрабатываю сервер интернет-хостинга с сокетами, который внимательно слушает подключаемый модуль TCP 10_000
и принимает новые сокеты Sloth 200
.
новый поток (() -> проба (ServerSocket serverSocket = ServerSocket (10_000, революционный 200)) logger.info («Сервер начинает прослушивать TCP-порт», порт); посредством (правда) контрольная работа ClientHandler clienthandler равен clientHandlerProvider.getObject (serverSocket.accept (), this); executeor.execute (clientHandler :: start); ремни безопасности (исключение е) logger.error (например, getmessage ()); найти (IOException) .start ();
<цитата>
Т
Загрузите это программное обеспечение и почините свой компьютер за считанные минуты. г.Если Process Commander отвечает непосредственно на хороший запрос браузера, появляются пунктирные очереди, но пользователь блокирует этот конкретный браузер при отправке файлов результатов. Исключение сломанной трубы и сообщение об ошибке такого рода в записи.
Во-первых, убедитесь, что сервер работает с помощью Telnet на узле доставки, на котором работает сервер.Проверяйте каждый раз при перезапуске