| idec.talks | HOME |
| AL>>> А если между запросами пришло не одно сообщение, а несколько десятков? Снова тянуть весь индекс, который может весить мегабайты? Так я точно знаю насколько изменилась длина индекса с прошлой сессии и могу скачать соответствующий слайс индекса. mirage>> Несколько десятков ID и получит. Только новое. AL> Каким образом фетчер узнает по одному ID сколько ему сообщений зпрашивать в слайсе? Вот он запомнил, что поледним получил сообщение mzu2V8Iz3VIAVeDg0TOi. Как он узнает сколько именно тянуть? Фетчер знает сколько ему надо максимум запросить чтобы не подавиться, по каким-либо причинам. Допустим это 100 idшников. Он запрашивает 100 записей от последнего id. В итоге будет 2 случая: 1. Придет меньше 100 id - запоминаем последний, конец. 2. Придет 100 id - запоминаем последний и запрашиваем снова 100 от него. mirage>> Вот есть на ноде в эхе сообщения: ID1 ID2 ID3. mirage>> Фетчер качает их и запоминает что последнее скачаное для этой ноды-эхи - ID3. mirage>> На ноду еще приходят сообщения: ID4 ID5 ID6. mirage>> В следующий раз фетчер спрашивает у ноды: дай все что после ID3. mirage>> И получает ID4 ID5 ID6 и запоминает ID6. mirage>> Весь индекс тянуть заново не надо. AL> Это будет уже совсем другой набор договорённостей. Можно придумать что угодно, но есть такая вещь, как совместимость. В любом случае, преимуществ такого подхода пока не видно. Куда нужнее личная переписка КМК. Это было предложение на вопрос в дискуссии о не совсем ясном числе в ответе API. Ну и это может быть расширением. +++ Caesium/0.4 RC1 |