|
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
|
|
Как отключить склеивание TCP пакетов?10.06.2019, 19:05. Показов 5801. Ответов 8
Метки нет (Все метки)
При отправке данных в большом количестве, например по 40 и 576 байт в случайном порядке, то на стороне сервера при считывании (
клиент.recv(4096)) выясняется, что пакеты склеены. Когда ожидается 40 байт, приходит 656 (40 + 40 + 576).сервер.setsockopt(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1) не помогает избежать проблемы.Если что, то OS Ubuntu 18.04, но вряд ли это как-то влияет на работу сокетов.
0
|
|
| 10.06.2019, 19:05 | |
|
Ответы с готовыми решениями:
8
Склеивание пакетов в TCP Как сделать фильтрацию в iptables по состоянию tcp-пакетов?
|
|
|
||
| 10.06.2019, 19:09 | ||
|
Нормально ожидать сегментации и буферизации. На прикладном/программном уровне Вы должны сами надстроить свой протокол над TCP который будет позволять различать Ваши сообщения (не пакеты!!!). Самый банальный пример первыми байтами слать размер текущего сообщения, а за ним данные(c этим размером). Более сложный пример слать "заголовок" потом данные.
1
|
||
|
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
|
||
| 10.06.2019, 19:31 [ТС] | ||
|
Дело в том, что нужно произвести имитацию работы компьютерной сети. Программа будет тестировать нагрузку компьютерной сети. Представим, что каждый отдельный пакет это данные отправленные с разных хостов. Была идея сделать задержку после отправки TCP пакета на десяток доли миллисекунд, но может как-то этого можно избежать? Дело в том, что идет замер времени, и возможно данная задержка после отправки пакета может негативно повлиять на конечный результат.
0
|
||
|
|
||
| 10.06.2019, 19:53 | ||
Сообщение было отмечено anapshy как решение
РешениеТаким образом отправив по TCP некий структурированный с вашей точки зрения набор данных вы получаете на приемнике all inclusive :-). Как вы будете разбирать\парсить полученный чанк данных - решать вам. Варианты вам предложили. Самое простое - высылать размер чанка и потом считывать ровно столько сколько указано.
1
|
||
|
153 / 148 / 66
Регистрация: 20.02.2014
Сообщений: 556
|
|||
| 17.06.2019, 07:27 | |||
Сообщение было отмечено anapshy как решение
РешениеДобавлено через 28 минут anapshy, кстати, обратите внимение так же на флаг TCP_QUICKACK
0
|
|||
|
153 / 148 / 66
Регистрация: 20.02.2014
Сообщений: 556
|
|
| 17.06.2019, 17:33 | |
|
0
|
|
|
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
|
||
| 20.06.2019, 12:09 [ТС] | ||
|
Задается передаваемый объем в байтах. От объема находится процентное соотношение пакетов по 40, 576, 1500 байтов (с учетом IP заголовка). Задается процентное соотношение TCP & UDP пакетов. Выбирается порядок следования пакетов по их размеру: по возрастанию, по убыванию, в случайном порядке. Отправляются пакеты на клиент. После клиент вычисляет объем пришедших данных, скорость передачи, средние значения, медианные по чему только можно и нельзя, время... . После провести тесты на корпоративной сетке с разными параметрами запуска и посмотреть как себя поведет сеть. Ещё есть EMIX примерно тоже самое, но размер передаваемых пакетов фиксированный + так же меняется соотношение TCP & UDP. Так же можно ICMP сюда приплести. Отключение алгоритма Нейгла у меня не работает. Делал тесты на других ОС и на Ubuntu18.04 - всё четко. Проблему разрешил тем, что не производятся замеры времени между пришедшими пакетами, а высчитывается общий объем пришедших данных на 1-м тесте. Провести несколько тестов показалось целесообразнее, чем 1 тест с замерами времени между пришедшими пакетами, т.к. эта информация оказалась не такой важной. Конец. Добавлено через 2 минуты Программка собой представляет типо iperf, только с более гибкой настройкой.
0
|
||
| 20.06.2019, 12:09 | |
|
Помогаю со студенческими работами здесь
9
Инкапсуляция пакетов TCP/IP Прошивка TCP/IP пакетов Расшифровка TCP пакетов Модификация TCP/IP пакетов Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git
main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели
8ATzM_2aurI
|
|
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2.
Задача: запретить редактирование документа, если он открыт у другого пользователя.
/ / . . .
|
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои.
А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
|
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
kYBz3eJf3jQ
|
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
|