poll. (запущен через поток) Thread(target=bot.infinity_polling, args=()).start() создал команду по факту тоже работает через long poll. (django) при ее вызове (когда django уже запущен) пишет ошибку: TeleBot: «A request to the Telegram API was unsuccessful. Error code: 409. Description: Conflict: terminated by other getUpdates request; make sure that only one bot instance is running» как понимаю из-за того что вторая команда использует request и это мешает боту? второго экземпляра бота точно не создано.
20:46 07.02.2022
24 ответов
Ошибка в том, что телеграм получает 2 или больше запроса на получение обновлений для бота
20:48 07.02.2022
Ivan Автор вопроса
Savva Mirzoyan
Ошибка в том, что телеграм получает 2 или больше з.
не совсем понимаю как это связано с командой которую я создал. она ведь бота не использует.. без ее запуска этой проблемы нет
20:50 07.02.2022
Ivan
не совсем понимаю как это связано с командой котор.
Чудес не бывает, ищи где запускаешь второй поллинг. Либо, если джангисты ещё не умерли от старости, скидывай код, может кто поможет)
Short Polling vs Long Polling vs WebSockets — System Design
21:38 07.02.2022
Ivan Автор вопроса
Oleg A.
Чудес не бывает, ищи где запускаешь второй поллинг.
Да я уверен что второго поллинга для бота нету) эта ошибка возникает когда я запускаю команду и она делает request запрос к киви) а бот вот только на потоке один раз и все, как только я отключаю команду с киви так ошибки сразу перестают сыпаться в консоль
21:40 07.02.2022
Ivan Автор вопроса
А что от старости то? что за приколы, я тут на практике изучаю его) а говоришь как будто теперь это технологии предков ♂️
21:46 07.02.2022
Ivan
А что от старости то? что за приколы, я тут на пр.
Не то что бы «технология предков», но крайне не доброжелательный к новичкам и мало реально крутых специалистов по нему.
21:48 07.02.2022
Ivan
А что от старости то? что за приколы, я тут на пр.
Джангисты — это отдельный вид питонистов. Попробовать стоит, но применять джангу во всём точно не рекомендую. Любая составляющая джанги есть в более современном предоставлении
Источник: telq.org
Polling и Long polling
Что такое Long-Polling, WebSockets, SSE и Comet
Недавно один из подписчиков спросил, как работают уведомления вконтакте? Или других высоконагруженных проектах, ведь они приходят мгновенно и, если использовать обычный ajax, то сервер достаточно быстро упадет. Вот о том, какие существуют способы реализации данного функционала, мы и поговорим в сегодняшней статье.
Для начала рассмотрим, как вообще идет http запрос при обычной работе
Regular http
1. Клиент посылает запрос на вебстраницу к серверу
2. Сервер формирует ответ
3. Сервер посылает ответ клиенту
Polling Vs Webhooks
AJAX Polling
1. Клиент посылает запрос на вебстраницу серверу, используя обычный http(regular http)
2. Запрошенная страница выполняет JavaScript, который запрашивает файл от сервера через какой-то интервал времени(например, 0.5 секунд)
3. Сервер формирует ответ для каждого запроса и отсылает его обратно
AJAX Long-Polling
1. Клиент запрашивает страницу у сервера, используя обычный http
2. Запрошенная страница выполняет JavaScript, который запрашивает файл от сервера.
3. Сервер НЕ реагирует на запрошенную информацию и ждет, пока не появится новой информации
4. Когда появляется новая информация, сервер отсылает ее клиенту
5. Клиент получает новую информацию и НЕМЕДЛЕННО отсылает другой запрос серверу, запуская процесс ожидания на нем снова.
HTML5 Server Sent Events(SSE)
1. Клиент запрашивает страницу у сервера, используя обычный http
2. Запрошенная страница выполняет JavaScript, который открывает соединение с сервером
3. Сервер посылает событие клиенту, когда появляется новая информация
- Трафик в реальном времени от сервера клиенту, главным образом, то, что вам нужно
- Вы захотите использовать сервер, который имеет цикл событий
- Нет возможности соединиться с сервером с другого домена
HTML5 WebSockets
1. Клиент запрашивает страницу у сервера, используя обычный http
2. Запрошенная страница выполняет JavaScript, который открывает соединение с сервером
3. Сервер и клиент могут посылать друг другу сообщения, когда новая информация доступна(либо на сервере, либо на клиенте)
- Трафик в реальном времени от сервера к клиенту и от клиента к серверу
- Вы захотите использовать сервер, который имеет цикл событий
- Есть возможность соединиться с сервером с другого домена
- Есть возможность использовать третью сторону веб-сокет сервера, например, Pusher
Comet
Comet — это коллекция техник, которые были до HTML5 и которые используют потоковую передачу и долгосрочный опрос для достижения приложения, работающего в реальном времени.
Итак, мы рассмотрели возможные способы реализации данного функционала. У каждого способа есть как свои плюсы, так и свои минусы. Однако, сейчас лучшим и быстро развивающимся способом считается WebSockets. Но помните, что HTML5 поддерживают только современные браузеры и про старые, увы, придется забыть, если вы будете использовать сокеты.
В ближайшее время я буду писать статьи про каждый из этих способов, так что подписывайтесь на обновления сайта, чтобы не пропустить! 🙂
Спасибо за внимание и удачного вам кодинга!
Создано 30.07.2014 20:10:19
Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!
Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.
Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления
Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.
Порекомендуйте эту статью друзьям:
Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):
- Кнопка:
Она выглядит вот так: - Текстовая ссылка:
Она выглядит вот так: Как создать свой сайт - BB-код ссылки для форумов (например, можете поставить её в подписи):
Комментарии ( 4 ):
GALAPERIDOL 31.07.2014 09:25:52
Вот теперь ясно! Спасибо 🙂
kruty 02.08.2014 16:29:00
Ну, є одна проблема.. php створений, щоб помирати.. тому, треба обробляти на node.js і т.д, або ж якщо хочеться, щоб менше витрачало ресурсів — с++. І це.. це діло потрібно проксувaти nginx
administrator 23.05.2015 11:00:52
тоесть непрерывного айфрейма больше не существует по вашему?
fixruss 01.11.2016 08:16:29
Было бы не плохо посмотреть пример
Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.
Источник: myrusakov.ru