реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> error writing to socket: bad file descriptor, Падает сервер при падении клиента
robix
сообщение May 29 2015, 14:59
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 126
Регистрация: 15-08-06
Из: Москва
Пользователь №: 19 556



Всем привет!

Написал сервер в Linux, который с большой скоростью, сотни мегабит, передает поток клиенту.
В общем все работает хорошо за исключением одного но: если во время передачи большого потока
вырубить клиента, то сервер падает с выдачей сообщения:
error writing to socket bad file descriptor

Перед каждым вызовом функции write или send проверяю состояние сокета, после отправки тоже проверка.
В свойствах send ставил флаг MSG_NOSIGNAL, тоже не помогает.

Коллеги, помогите чем можете!!!

Go to the top of the page
 
+Quote Post
gerber
сообщение May 29 2015, 16:13
Сообщение #2


Знающий
****

Группа: Участник
Сообщений: 750
Регистрация: 1-11-11
Пользователь №: 68 088



Цитата(robix @ May 29 2015, 18:59) *
Коллеги, помогите чем можете!!!

Если клиент закрыл TCP-сокет - серверу уже ничем не помочь! biggrin.gif
Падать не нужно, нужно просто корректно обрабатывать эту ситуацию - например, прекращать передачу и тоже закрывать файловый дескриптор сокета. Достаточно проанализировать значение, возвращаемое функцией send (write).
А проверять до и после состояние сокета смысла никакого нет.


--------------------
"... часами я мог наблюдать, как люди работают." (М. Горький)
Go to the top of the page
 
+Quote Post
krux
сообщение May 29 2015, 17:00
Сообщение #3


Профессионал
*****

Группа: Свой
Сообщений: 1 700
Регистрация: 2-07-12
Из: дефолт-сити
Пользователь №: 72 596



зависит от операционки, настроек среды, протокола (TCP/UDP) и пр.

проверять состояние сокета до отправки данных - вообще нет смысла. операционка не обновляет состояние тех структур, которые вы пытаетесь читать.
дальше после вызова send(), проверять состояние сокета.

если у вас TCP, то предполжу, что:
- закончился сокет-буфер операционки, поскольку клиент отрубился без оповещения (не послал FIN) и TCP-стек ждёт 2 минуты после последнего ACK
т.е. вы не ждёте того кода ошибки сокета, который вам возвращает операционка, не обрабатываете его, вместо этого тупо пытаетесь молотить данные дальше.


--------------------
провоцируем неудовлетворенных провокаторов с удовольствием.
Go to the top of the page
 
+Quote Post
gerber
сообщение May 29 2015, 19:26
Сообщение #4


Знающий
****

Группа: Участник
Сообщений: 750
Регистрация: 1-11-11
Пользователь №: 68 088



Цитата(krux @ May 29 2015, 21:00) *
если у вас TCP, то предполжу, что:
- закончился сокет-буфер операционки, поскольку клиент отрубился без оповещения (не послал FIN) и TCP-стек ждёт 2 минуты после последнего ACK

Судя по тексту ошибки, вынесенной в название темы, клиент как раз отрубился корректно (т. е. послал FIN и закрыл соединение), возможно, это сделала не сама программа-клиент, а операционка при завершении программы-клиента, закрывая все открытые им файловые дескрипторы и сокеты в том числе. На стороне сервера, получив FIN, стек TCP/IP тоже закрыл соединение, поэтому производить какие-то операции с закрытым дескриптором нельзя, что и видим. Просто это нужно учитывать и обрабатывать корректно, а не молотить и сносить уже освобожденные буфера.


--------------------
"... часами я мог наблюдать, как люди работают." (М. Горький)
Go to the top of the page
 
+Quote Post
robix
сообщение Jun 1 2015, 12:01
Сообщение #5


Частый гость
**

Группа: Свой
Сообщений: 126
Регистрация: 15-08-06
Из: Москва
Пользователь №: 19 556



Спасибо, коллеги!
Ваша убедительность дала результат.
Оказывается проверял возврат send на отрицательные значения, но не на ноль.
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 12th July 2025 - 11:51
Рейтинг@Mail.ru


Страница сгенерированна за 0.0138 секунд с 7
ELECTRONIX ©2004-2016