IRCaBot 2.1.0
GPLv3 © acetone, 2021-2022
#dev
/2024/03/31
~AreEnn
~R4SAS
~orignal
~villain
&N00B
+Xeha
+relaybot
DUHOVKIN
Guest18377
HackerMan
KabaOS
Most2
Nausicaa
Ruskoye_911
Trusishka
Vort
`
acetone_
anon3
b3t4f4c3
mittwerk
nemiga
not_bob_afk
plap
poriori_
profetikla
segfault
soos
teeth
tensor
un
weko_
whothefuckami
onon Поймал странный баг, клиент шлёт мне nack а у меня в sentPackets такого seqn нет...
Vort все отправки, приёмы, перепосылки, переносы из одного массива в другой вывести в лог - и ситауция станет понятной
Vort клиент то тоже "свой"
Vort это тот случай, когда багу некуда бежать :)
Vort разве что логированием можно "спугнуть", но это тоже решается
onon2 Ну я его пока только два раза ловил, я пока другим занимаюсь, потом может разберусь.
Vort это может, кстати, быть связано с зависанием запросов к java серверам
Vort тоже надо будет когда-то погонять. я видел такое на сайте notbob
onon2 Ну он только в одном месте стирается из списка, m_SentPackets.erase (it++);
onon2 Может он как-то неправильно инкремент считает
Vort традиционно, может быть проблема с многопоточностью, надо смотреть, из одного ли треда все функции доступа к объекту вызываются
onon2 std::round () в какую сторону округляет?
onon2 Нашёл
onon2 С этим багом с пропадающими пакетами разбираться пока желания нету, но на всякий случай скину сюда информацию.
onon2 Я получил аск с ackThrough 21131, удалил его у себя из m_SentPackets потом получил еще один аск 21131 вроде дубль, ничего не делал.
onon2 Потом пришёл аск с ackThrough 21133 и nackCount=1 но у меня в m_SentPackets того пакета который nack, уже не было.
onon2 Мне думается проблема на стороне клиента.
onon2 Ну или тут чего то не то удаляется m_SentPackets.erase (it++);
Vort мысль наугад: может, пакеты (ack / nack) местами поменялись, SSU2 такое умеет
Vort "того пакета который nack" - ну вот поэтому все seqn надо выводить в консоль. будет понятнее
onon2 Это надо переписывать код и сидеть конкретно этот баг ловить, говорю же, пока другим занимаюсь.
onon2 Но в туду лист запишу, может займусь потом.
Vort так как чётко баг определяется - пришёл NACK, а пакета нету?
Vort могу на локалхосте погонять
onon2 Ну да
onon2 Ты лучше новый CC для стримов погоняй
onon2 Я код скидывал
Vort а ты проблему с RTO исправлял?
onon2 Что за проблема рто?
Vort ну RTO - это же время, через которое идёт перепосылка, если не пришло ACK, верно?
onon2 Ну
onon2 А что за проблема была?
Vort так вот в твоём коде (в прошлой версии) я на самом первом пакете при неудачном туннеле видел перепосылку через 3 * RTO вместо 1 * RTO
Vort вот и спрашиваю - в новой версии исправлено или нет
onon2 Даже не знаю что сказать
onon2 Вот это ты проблему нашёл
onon2 Прям баг из багов
onon2 Ну я там сделал константу на ретрансмит в 6 сек, но не похоже чтобы это сильно улучшило ситуацию
Vort когда в коде написано одно, а подразумевается другое - это довольно важная проблема
Vort дело даже не столько в том, какое влияние на работу кода это оказывает
Vort иногда две таких проблемы компенсируют друг друга и вообще видимого эффекта нету (это просто пример)
onon2 Не надо метать бисер перед свиньями, я всё равно не понимаю о чём ты.
Vort но понимать и дорабатывать такой код - очень сложно
onon2 Я тебе и скинул, что бы ты саму логику понял, как нужно сделать, и сделал правильно.
Vort "я всё равно не понимаю о чём ты" - о теоретическом смысле RTO и том, как этот термин используется в коде на самом деле
onon2 Так всё правильно там используется
Vort перепосылка через 1 * RTO идёт?
onon2 Если за три РТО не получили ни однога аска - ретрансмит
onon2 А если получили наск - проверяем "старые" пакеты
onon2 Старые те которые больше РТО
Vort поэтому я и задал вопрос "RTO - это же время, через которое идёт перепосылка, если не пришло ACK, верно?"
Vort а в коде - 3 * RTO
onon2 Или я не правильно объясняю, или у тебя сложности.
onon2 Ты имеешь в виду, почему там написано 3*РТО а не 3*РТТ?
onon2 Ну так чтобы уменьшить влияние джиттера
onon2 Можешь написать туда 3*(РТТ+jitter)
Vort вопрос в определении RTO. "RTO - это ****"
onon2 Будет то же самое но тебе понятнее будет
orignal я кстати так и не понял в чем между ними разница
Vort сейчас же получается "RTO - это место, где хранится какое-то значение, которое потом как-то где-то используется"
onon2 Всё правильно, используется в перепосылках, при проверке "втарости" пакета
Vort "RTO - значение, которое используется при перепосылках. то так, то сяк"
onon2 Ну и да, то что у меня там названо джиттером, это не совсем джиттер
orignal кстати я тут себе макось 12 поставил в виртуалбокс
onon2 На самом деле джиттер не так считается
orignal так что след релиз соберу более новым шлангом
onon2 Ну и назови это как хочешь
onon2 Я сейчас ещё пару фильтров добавил, окно растянул, и он теперь может 1мб/сек через 6 хопов гнать с минимальным пингом.
orignal а хопы то потянут это?
onon2 Ну он выжимает максимум, что дают.
onon2 Некоторые позволяют только около 20 кб/с он так и работает.
onon2 Хотя не правду написал, он на данный момент может максимум 1000 пакетов в секунду, даже если ему разрешат больше.
onon2 Всё потому что я не знаю как сделать boost::posix_time::milliseconds(1) меньше единицы
onon2 Но может быть пока и не нужно больше тысячи пакетов в секунду...
orignal надо использовать boost::posix_time::microseconds
orignal разве не лошично?
onon2 А надо больше одного мб/с на один стрим?
orignal а чего нет то?
orignal у меня в клирнете бывает и по 50 мегабайт в секунду файл качается
onon2 Ну я тогда как с фильтрами разберусь, попробую переписать, вроде должно быть не сложно.
orignal ну я счас проверю твой код локально
orignal у меня и клиент и сервер там
Vort onon2: вопрос про RTO можно и по-другому переформулировать: через какой интервал времени должна идти перепосылка пакета? "через 3 * RTO"? "через 1 * RTO"? "иногда через 3 * RTO, иногда через 1 * RTO"? ещё какой-то вариант?
onon2 Ты спрашиваешь, чтобы получить ответ, или чтобы выебнуться?
onon2 Мне как-то похер, я хочу чтобы итупи быстро работал, а не пытаться писать правильный код, который не умею.
Vort чтобы понять, соответствует ли идея кода (теория) практике (тому, что написано)
onon2 Идея в том, чтобы слать ретрансмиты только если получили наск
onon2 А через 3*РТО мы шлём по одному пакету что бы восстановить связь
Vort получили nack - шлём через 1RTO, не получили - шлём через 3RTO. так что ли?
onon2 Потому что нам никто не отвечает
onon2 Вообще лучше через 2*RTO
Vort ну общую мысль я правильно уловил?
onon2 Но с такими проблемами с лизсетами лучше туннель часто не менять
onon2 Правильно уловил
Vort окей
Vort и через 3RTO перепосылка уже в другой туннель пойдёт что ли?
Vort подозреваю, что у этого алгоритма будут проблемы с редким ping-подобным обменом данными наподобие IRC
onon2 Ну да, если нам никто не ответил через 3 rtt подозреваем, что с туннелем что-то не так
Vort один просранный пакет - и уже ищем новые туннели
onon2 не один а три
orignal надо не три а тридцать
onon2 почему
Vort гляну позже код получше, где там это "три" прописано
onon2 я бы сделал два
Vort ещё одна проблема кстати (которую я толком не проверил) - новый код, похоже, будет пытаться отправить SYN полчаса
Vort юзеры обычно столько не ждут
onon2 Ну и что, памяти вроде не ест
Vort я думаю, больше 1-2 минуты ждать восстановления связи не стоит
onon2 Бывает и через пять минут у меня стрим оживает
onon2 Я же говорю какая-то херня с лизсетами
onon2 Или с чем-то ещё
Vort "<onon2> не один а три" - всё же спрошу - где это указывается?
Vort боюсь не найти в коде, лучше сразу спросить
onon2 Ну три аска не получили
Vort так где это число прописано?
onon2 Нет такого числа
Vort значит не три
Vort а как получится
onon2 Ну и не один
Vort если по стриму ничего не идёт несколько минут
Vort а затем отправляется ровно 1 байт
Vort если будет потеря - забракуется туннель
Vort надо будет потом над этим подумать
onon2 Я же спрашивал, ты информацию хочешь или выебнуться, я подозреваю что второе
Vort onon2: не хотелось, чтобы с какой-то из групп юзерских протоколов новый алгоритм работал хуже старого
Vort паттерн "долго ничего не происходит, а потом отправляется один байт" - довольно распространён
Vort не каждый стрим - это скачка файла. надо учитывать это при разработке алгоритма
Vort ну и просить посмотреть алгоритм, а затем при появлении критики и просьб уточнений обвинять в выёбывании - неконструктивно
onon2 Я пока критики не увидел, а на все уточнения стараюсь отвечать подробно насколько могу.
onon2 А смена туннеля не должна вообще вызывать проблем с точки зрения архитектуры итупи
onon2 Если это создаёт проблемы, нужно не избегать таких ситуаций а пытаться исправить проблему с туннелями.
onon2 Но если ты считаешь, что будет лучше не менять туннель на первый таймаут - сделай так, как было с кейсами
Vort дополнительные ресурсы сети расходуются - на поиск RI. может, это и мелочь, не знаю
onon2 У нас задача сделать двигатель для ракеты, а не уменьшать ракету под имеющийся двигатель.
Vort я предполагаю, что вариант "с кейсами" был реализован не просто так, была какая-то причина сделать именно так
Vort и прежде чем его выкидывать, лучше с этой причиной ознакомиться (порасспрашивать, к примеру, да)
Vort может, он и плох. вполне допускаю. но это неочевидно
onon2 Там другой момент плох, что смена туннеля, по всей видимости, задевает другие стримы к этому же дестинейшену.
onon2 И так быть вообще не должно
onon2 Поэтому всё так плохо работает.
onon2 Т.е. алгоритм со сменой туннеля - сам по себе адекватный, но в текущей реализации это создаёт проблемы. Поэтому я не могу сказать что плохо а что хорошо.
proxy пасха - закрыто всё, даже продуктовые
proxy а, не сюда, сорян
Vort onon: вопрос нагрузки на сеть обдумать надо независимо от других свойств
Vort про другие стримы: у меня тоже подобное подозрение возникло когда я расспрашивал про работу GarlicRoutingPath
Vort не хотел сейчас разводить это обсуждение, но, видимо, придётся. сейчас буду вопрос формулировать
Vort orignal: допустим, отправляющая сторона имеет 5 хороших исходящих туннелей, принимающая сторона имеет 5 хороших входящих туннелей. всего получается 25 пар
Vort позволяет ли сеть i2p одновременно отправить один и тот же пакет через все 25 пар и успешно получить ответы (в случае, если никаких помех этому не будет)?
Vort имею в виду ситуацию с единственным активным стримом
orignal пакет это что? Сообщение Data или Garlic?
Vort такие, которые стримы делают. точно не знаю. SYN стримовый, допустим
orignal тут как говорится две большие разницы
orignal одно и то же Data несколько раз без проблем
orignal второй Garlic пройдет потому что таг одноразовый
Vort ок, SYN стрима как отправляется?
Vort ну и не столь важна одинаковость. допустим, разные пакеты. seqn 1 в одну пару, seqn 2 во вторую пару и так далее
orignal через выбранную пару
Vort не помешает ли одна отправка другой?
orignal или наугад или если уже есть то через нее
orignal не помешает но как считать RTT?
Vort я имел в виду вопрос "Data или Garlic" - не помню, что стримы шлют просто
orignal стрим сначала делает Data потом оборачивает в Gralic
Vort а, ну значит Garlic
orignal ну он может быть только один
orignal дважды ты его отправить то можешь
orignal но второй не расщифруется
Vort окей, значит проблем, о которых я думаю, в теории быть не должно
Vort а вот что там на практике - надо разбираться
Vort onon: в теории и если не учитывать нагрузку на сеть получается, что прыгать можно по туннелям сколько и как угодно и ничего при этом ломаться не должно
Vort но я по структурам данных сомневался
Vort там есть общие объекты для нескольких пар и они у меня вызывают сомнения
onon Может они лизсеты помечают как плохие или что-то в этом роде
onon Другие стримы имею в виду
onon Вот у меня стрим завис, я открываю новый параллельный стрим и - чудо старый стрим оживает
Vort говорю же, в коде есть объекты сессий и их надо хорошенько рассмотреть
onon А новый стрим может берёт с флудфила
onon А старые уже все протухли
Vort но можно и просто "с нуля" погонять проблему
onon а бывает наоборот стрим работает нормально, запускаешь ещё несколько, и всё ломается.
Vort m_RoutingSession посмотри
Vort я пока ещё не понял, как он работает, но смотрю на него с подозрением :)
onon Не, я не разберусь. Мне придется код стримов из головы выгрузить.
Vort "<onon> А новый стрим может берёт с флудфила" - надо разобраться, как вообще лизсеты обновляются. я пока что без понятия
onon Я тебе давно говорил что это одна из самых противных проблем, и её решение должно быть в приоритете.
Vort решил я опять сделать тесты с 3 узлами, половить nack проблему. а попал на лизсетовую хрень, похоже
Vort отправка с узла 1 на узел 2 через узел 3
Vort поставил запускаться узлы, отошёл. когда возвращаюсь - вижу, что 3 узел вывалил ошибку про занятый порт
Vort закрываю ошибку, вижу что и 1 и 2 узлы смогли уже через 3 построить туннели
Vort да вот только связи между 1 и 2 узлом не было и довольно долго
Vort минут 5 наверно
Vort похоже, раз лизсет сразу опубликоваться не смог, то последующие попытки были очень не сразу
Vort ещё и тесты туннелей сфейлились. ппц. на локалхосте
Vort и не один раз. вообще на 1 узле тесты перестали проходить
Vort ещё и два стрима дохлых висят бесконечно
Vort пытаюсь закрыть дохлые стримы - получаю сообщение Stream closed, но стрим остаётся на месте
Vort конкретно я узел заглючил. не пойму только, как
Vort возможно, в баг с часами вляпался. перезагружаю всю эту конструкцию
Vort это я просто криво логирование NACK`ов сделал. ппц )
Vort точнее, зависание - из-за кривого логирования. а вот почему связи не было - вопрос интересный
Vort добавил вот такой код к версии из основной ветки: paste.i2pd.xyz/?6de4853285d8b0ce#8CEr6CPTAVP3BBX2XSDb5Ne1Zqf5MxV2CZ4sStGj31q1
Vort при тесте на локалхосте проблема не попалась
Vort а вот при тесте с рандомными хопами (1+1) - словилась где-то через минуту
Vort при втором 2хминутном тесте ни разу не вылезла
Vort при третьем - вылезла два раза
Vort даже не два, а три
Vort в некоторых случаях ситуация кажется довольно простой:
Vort это просто дубли пакетов
Vort в некоторых сложнее
Vort но, скорее всего, это происходит из-за поменянных местами пакетов
Vort onon: вот более делальный лог по NACK`ам: paste.i2pd.xyz/?6a78d0a850cccd18#EhRcyKARigkxWf2Pi9mHQFEaghT52518DDh15ezgVWGQ
Vort идут ackThrough ... 38523 38552 38557 38576 38400 (бесполезный) 38491 (проблемный) 38589 38617 38618 ...
Vort то есть, ackThrough 38400 и 38491 просто задержались
Vort фича SSU2 в действии :))
orignal не понял
Vort onon удивлялся, почему приходят nack`и на несуществующие в m_SentPackets пакеты
Vort я и разобрался, почему - потому что SSU2 переставляет местами пакеты
Vort и эти nack`и просто старьё
orignal ну так там же диапазоны