crossplatform.ru

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

Andrewshkovskii
  опции профиля:
сообщение 8.12.2011, 11:03
Сообщение #1


Активный участник
***

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

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




Репутация:   1  


Есть клиент и сервер. Постоянно обмениваются сообщениями разной длинны.
Сейчас, что бы понять, где кончается одно сообщение и начинается другое, используется конвенция сообщений такая :
Цитата
%длина_всего_соообщения%|%тело сообщения%


Но с этим иногда бывают косяки. Есть ли какие-то ещё конвенции или парадигмы, как лучше общаться сокетам большими сообщениями?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
Влад
  опции профиля:
сообщение 10.12.2011, 19:19
Сообщение #2


Участник
**

Группа: Участник
Сообщений: 146
Регистрация: 20.3.2009
Из: Санкт-Петербург
Пользователь №: 627

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




Репутация:   8  


Гмм. Что-то это из категории загадок.... :-)

Во-первых, в TCP нет никаких "пакетов" - т.к. это потоковый протокол передачи данных. Во-вторых, крайне удивительно, что "пакеты теряются" - т.к. это протокол с гарантированной доставкой.

Думаю, что нужно заниматься поиском багов в прикладном уровне.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Andrewshkovskii
  опции профиля:
сообщение 10.12.2011, 22:42
Сообщение #3


Активный участник
***

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

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




Репутация:   1  


Цитата(Влад @ 10.12.2011, 19:19) *
Гмм. Что-то это из категории загадок.... :-)

Во-первых, в TCP нет никаких "пакетов" - т.к. это потоковый протокол передачи данных. Во-вторых, крайне удивительно, что "пакеты теряются" - т.к. это протокол с гарантированной доставкой.

Думаю, что нужно заниматься поиском багов в прикладном уровне.

А поток из чего состоит?
Т.е. Вы утверждаете, что используя TCP/IP протокол - вы никогда не потеряете фрейм с данными?Никогда-никогда? Ни при каких условиях?
Вся это гарантированная доставка для сферического коня в вакууме. Не забывайте оборудование - которое может сбоить, кабеля повреждаться и т.п..
И в догонку:
Цитата
TCP обеспечивает надёжную непрерывную передачу данных, исключающую потерю данных или нарушение порядка их поступления или дублирования, может перераспределять данные, разбивая большие порции данных на фрагменты и наоборот склеивая фрагменты в один пакет.

Ок, я не правильно назвал пакеты - порциями, тут я не прав. Суть была в том, что порция данных может потеряться, тупо оборудование засбоит и всё - не получите вы свой кусочек. Или какой-нибудь софт, вроде FW заблочит.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
BRE
  опции профиля:
сообщение 10.12.2011, 22:56
Сообщение #4


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

Группа: Участник
Сообщений: 1112
Регистрация: 6.3.2009
Из: Ростов-на-Дону
Пользователь №: 591

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




Репутация:   44  


Цитата(Andrewshkovskii @ 10.12.2011, 23:42) *
Суть была в том, что порция данных может потеряться, тупо оборудование засбоит и всё - не получите вы свой кусочек. Или какой-нибудь софт, вроде FW заблочит.

Нет, порция потеряться не может. Стек контролирует порядок получения пакетов и если необходимо, будет запрашивать пакет заново.
Пока он этот пакет не получит, дальше он ничего отдавать не будет. Программа никогда не получит данные из сокета с "дыркой" посредине.

Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме
- Andrewshkovskii   Прием данных по сокету. Какие конвенции лучше?   8.12.2011, 11:03
- - sidsukana   А чем тебя не устраивает обмениваться структурами?...   8.12.2011, 11:21
- - kuzulis   ЦитатаЕсть ли какие-то ещё конвенции или парадигмы...   8.12.2011, 12:17
|- - Andrewshkovskii   Цитата(kuzulis @ 8.12.2011, 12:17) Цитата...   8.12.2011, 14:05
- - ssoft   Цитата(Andrewshkovskii @ 8.12.2011, 12:03...   8.12.2011, 13:34
- - kuzulis   ЦитатаЯ вроде говорил о том, что над протоколом, а...   8.12.2011, 14:43
|- - Andrewshkovskii   Цитата(kuzulis @ 8.12.2011, 14:43) Цитата...   8.12.2011, 16:09
- - ssoft   Цитата(Andrewshkovskii @ 8.12.2011, 15:05...   8.12.2011, 15:43
- - Влад   Цитата(Andrewshkovskii @ 8.12.2011, 12:03...   9.12.2011, 15:45
|- - Andrewshkovskii   Цитата(Влад @ 9.12.2011, 15:45) Цитата(An...   9.12.2011, 16:26
- - Влад   Гмм. Что-то это из категории загадок.... :-) Во-п...   10.12.2011, 19:19
|- - Andrewshkovskii   Цитата(Влад @ 10.12.2011, 19:19) Гмм. Что...   10.12.2011, 22:42
|- - BRE   Цитата(Andrewshkovskii @ 10.12.2011, 23:4...   10.12.2011, 22:56
- - Andrewshkovskii   Т.е. , если я передаю файл, скажем, 1 гб, и где-то...   10.12.2011, 23:49
- - BRE   Если пакет теряется - стек будет просить его переп...   11.12.2011, 0:06
- - Влад   А если ты эту ошибку не обрабатываешь, то это баг ...   11.12.2011, 13:05
|- - BRE   Цитата(Влад @ 11.12.2011, 14:05) (С колле...   11.12.2011, 14:35
- - Andrewshkovskii   Сообщение перемещено Сюда   14.12.2011, 22:18


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


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


RSS Рейтинг@Mail.ru Текстовая версия Сейчас: 23.4.2025, 16:52