crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> Обрыв соединения QTcpSocket
OrSOn
  опции профиля:
сообщение 16.2.2010, 14:47
Сообщение #1


Студент
*

Группа: Участник
Сообщений: 46
Регистрация: 8.12.2009
Пользователь №: 1289

Спасибо сказали: 0 раз(а)




Репутация:   0  


Всем добрый день! Столкнулся с довольно неприятной проблемой при работе с сокетами... Суть проблемы в следующем:

Имеется сервер и клиент, для общения используют сокеты. В некий момент времени клиент рушится (ну или связь падает, не суть важно), при этом сервер пытается что-то писать в сокет, что приводит к ошибке. Чтобы избежать этого, пробовал ввести проверку

if( tcpSocket->state() != 3 )
    return;
tcpSocket->flush();


Так вот случаются ситуации, что проверка состояния проходит, а сразу после нее до начала проталкивания информации клиент падает и на tcpSocket->flush() снова вылетаю с ошибкой.

Если кто сталкивался с подобным, подскажите, пожалуйста, как это можно обойти...

Сообщение отредактировал OrSOn - 16.2.2010, 14:48
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
OrSOn
  опции профиля:
сообщение 19.2.2010, 13:26
Сообщение #2


Студент
*

Группа: Участник
Сообщений: 46
Регистрация: 8.12.2009
Пользователь №: 1289

Спасибо сказали: 0 раз(а)




Репутация:   0  


Изначально так и планировалось, чтобы на 1 запрос 1 поток... Но суть в чем. Имеется система для передачи больших объемов информации (обновления данных по сети). Причем данные могут быть разнотипными (с разными приоритетами). В итоге имеем большое число возможных одновременных подключений. Если создавать отдельные потоки для каждого соединения, то их может стать слишком много и передача "умрет", будет разом обновляться у всех, но ОЧЕНЬ медленно (не из-за сети, так из-за скорости чтения с жесткого диска). Поэтому было принято решение создать заранее ограниченное количество потоков, а все запросы от клиентов распределять между ними, но не просто так, а на передачу 1 файла, т.е. клиент подключился и попал в очередь. Дошла очередь до него - сокет отправлен в поток, передается ОДИН файл и сокет попадает обратно в очередь, а потоку передают следующий. Так сделано из-за приоритетов... Если давать возможность загружать сразу все файлы, то просто приоритетные запросы файлов, необходимых срочно, будут ждать очень долго... А если создавать по одному потоку на передачу одного файла одному клиенту - это будет глупо, по-моему..

З.Ы. нагорожено там из-за некоторых дополнительных требований, они тут ни при чем)))

Цитата(SABROG @ 19.2.2010, 13:19) *
Смотри что получается. Сокет находится в гуишном потоке, его обслуживает отдельный поток, это означает, что когда ты вызываешь метод write() ты напрямую обращаешься к методу объекта. В результате ты пытаешься записать данные из одного потока в другой напрямую.

Если ты не хочешь переносить сокет в тот же поток, который его обслуживает, то убедись, что обслуживающий поток эмитит сигнал о начале записи каких-либо данных и продолжает своё выполнение в то время, когда основной поток что-то пишет в сокет. Если ты все-таки хочешь вызывать read/write в обслуживающем потоке, то сокет должен принадлежать ему. Просто запомни, что любое взаимодействие между двумя объектами находящимися в разных потоках должно происходить через сигналы или события. Не должно быть никаких прямых вызовов методов одного объекта у другого. Конечно ничего не случиться, если метод threadsafe, но таковыми являются не все.


Я не могу отдавать сокет обрабатывающему потоку, ибо потом он возвращается в главный и может быть передан затем другим... А вот насчет передачи сигналов - если так получится, то будет круто, надо попробовать)))
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме
- OrSOn   Обрыв соединения QTcpSocket   16.2.2010, 14:47
- - sploid   так в чем проблема? в том что сервер не знает запи...   16.2.2010, 17:29
- - SABROG   Цитата(OrSOn @ 16.2.2010, 14:47) вылетаю ...   16.2.2010, 20:28
- - OrSOn   Обработать ошибку нельзя - полностью прерывается д...   17.2.2010, 10:07
|- - BRE   Цитата(OrSOn @ 17.2.2010, 10:07) Обработа...   17.2.2010, 10:15
- - OrSOn   while( tmpLength < file.size() ...   17.2.2010, 10:19
- - BRE   Покажи как создается объект tcpSocket и какие сигн...   17.2.2010, 10:25
- - OrSOn   Значит по порядку... Объект создается нормально, н...   17.2.2010, 10:34
- - BRE   Класс TcpSocket данные кеширует сам и отправляет и...   17.2.2010, 10:50
- - OrSOn   Увы, но удаления объекта не происходит. Я уже дума...   17.2.2010, 11:02
- - BRE   Ну так если ты хочешь отправлять синхронно, то поп...   17.2.2010, 11:39
- - OrSOn   Боюсь, что так будет не лучше, ибо сложнее отследи...   17.2.2010, 11:45
- - BRE   Как только ты записал последний кусок данных в сок...   17.2.2010, 12:11
- - OrSOn   Попробовал, ничего не вышло... Вот код: while...   17.2.2010, 14:50
|- - BRE   Набросал небольшой пример (клиент/сервер) для пере...   17.2.2010, 16:29
- - OrSOn   Спасибо, сейчас гляну Что-то я не совсем понял......   17.2.2010, 17:12
|- - BRE   Цитата(OrSOn @ 17.2.2010, 17:12) int writ...   17.2.2010, 17:23
- - OrSOn   Попробовал, но, увы, этот вариант врядли прокатит(...   18.2.2010, 13:15
|- - BRE   Цитата(OrSOn @ 18.2.2010, 13:15) Получает...   18.2.2010, 14:33
- - OrSOn   ну не знаю, я запускал в дебаге твой пример, так т...   18.2.2010, 14:35
|- - BRE   Цитата(OrSOn @ 18.2.2010, 14:35) ну не зн...   18.2.2010, 18:53
- - OrSOn   Да, что-то я тоже не заметил, спасибо, так работае...   19.2.2010, 11:50
- - BRE   Покажи подробно (закопипасть сюда) класс этого пот...   19.2.2010, 11:59
- - OrSOn   Ну все будет сложно сюда перенести, ибо много, я к...   19.2.2010, 12:15
- - SABROG   connect( this, SIGNAL( readF() ...   19.2.2010, 12:25
- - OrSOn   Сокет принадлежит главному потоку, объект NThread ...   19.2.2010, 12:31
- - SABROG   Это не правильно. Соединение не должно быть прямым...   19.2.2010, 13:01
- - OrSOn   У меня и так эта проверка стоит, согласен, можно у...   19.2.2010, 13:02
- - BRE   Сокет принадлежит главному потоку, а должен принад...   19.2.2010, 13:12
- - SABROG   Смотри что получается. Сокет находится в гуишном п...   19.2.2010, 13:19
- - OrSOn   Изначально так и планировалось, чтобы на 1 запрос ...   19.2.2010, 13:26
- - SABROG   Задача потока выполнять долгую операцию на фоне по...   19.2.2010, 13:45
- - OrSOn   Вот я и думал об этом как раз, чтобы обрабатывающи...   19.2.2010, 13:48
- - BRE   OrSOn, я скоро приеду домой и сброшу тебе пример а...   19.2.2010, 14:03
- - OrSOn   Ок, спасибо, буду ждать)   19.2.2010, 14:05
- - SABROG   Думаю вместо того, чтобы данные передавать с сигна...   19.2.2010, 14:37
|- - BRE   Цитата(SABROG @ 19.2.2010, 14:37) Думаю в...   19.2.2010, 15:06
- - SABROG   Цитата(BRE @ 19.2.2010, 15:06) А если при...   19.2.2010, 16:19
|- - BRE   Цитата(SABROG @ 19.2.2010, 16:19) В общем...   19.2.2010, 16:53
- - OrSOn   Спасибо, сейчас буду пробовать все посоветованное....   24.2.2010, 10:30
- - OrSOn   А такой вопрос еще... А можно ли рассматривать как...   24.2.2010, 16:10
- - SABROG   Цитата(OrSOn @ 24.2.2010, 16:10) а затем ...   25.2.2010, 2:43
- - OrSOn   А почему это я не смогу вернуть их в главный поток...   25.2.2010, 9:47
- - BRE   Пока я вижу один момент с перетягиванием объектов ...   25.2.2010, 12:14
- - OrSOn   Увы, при перемещении я не могу рвать коннект, в то...   25.2.2010, 12:44


Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


4 чел. читают эту тему (гостей: 4, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 3.12.2024, 23:24