Lista de verificaciones en despliegues

Lista de cosas a tener en cuanta cuando vayas a alojar un bot grande.

Puede que estes interesado en nuestras guías para alojar un bot. Mira Alojamiento / Tutoriales en el principio de la página para ver algunas de las plataformas que ya tienen guías dedicadas.

Errores

  1. Instala un manejador de errores con bot.catch (long polling) o en tu web framework (webhooks).
  2. Usa await en todas las promesas e instala linting, con reglas que obliguen a esto, así nunca te olvidas.

Envío de mensajes

  1. Envía ficheros por ruta o Buffer en vez de Stream,o al menos estate seguro de que conoces las trampas.
  2. Usa bot.on("callback_query:data") como un manejador alternativo para reaccionar a todas las consultas de devolución de llamada.
  3. Usa el transformer-throttler plugin para prevenir llegar a los límites.
  4. Optional. Considera usar el auto-retry plugin para automáticamente manejar los errores de espera.

Escalando servidores

Esto depende del tipo de despliegue.

Long Polling

  1. Usa grammY runner.
  2. Usa sequentialize con el mismo id de sesión que tu middleware de sesión.
  3. Revise las opciones de configuración de run (referencia de la APIopen in new window) y asegúrese de que se ajustan a sus necesidades, o incluso considere la posibilidad de componer su propio corredor a partir de sourcesopen in new window y sinksopen in new window. Lo principal a tener en cuenta es la carga máxima que quiere aplicar a su servidor, es decir, cuántas actualizaciones pueden procesarse al mismo tiempo.
  4. Considere implementar un apagado gradual para parar tu bot cuando tu quieres terminar con él (e.j. cambiar a una nueva versión).

Webhooks

  1. Asegúrese de no realizar ninguna operación de larga duración en su middleware, como las transferencias de archivos de gran tamaño. Esto lleva a errores de tiempo de espera para los webhooks, y el procesamiento de actualizaciones duplicadas, ya que Telegram reenviará las actualizaciones no reconocidas. Considere la posibilidad de utilizar un sistema de cola de tareas en su lugar.
  2. Familiarícese con la configuración de webhookCallback (referencia de la APIopen in new window).
  3. Si cambiaste la opción getSessionKey por la de tu sesión, usa sequentialize con la misma función de resolución de claves de sesión que su middleware de sesión.
  4. Si se ejecuta en una plataforma sin servidor o de autoescalado, establezca la información del botopen in new window para prevenir excesivas llamadas getMe.
  5. Considere utilizar webhook replies.

Sesiones

  1. Considere usar lazySessions explicadas aquí.
  2. Use la opción storage para configurar su adaptador de almacenamiento, de lo contrario todos los datos se perderán cuando el proceso del bot se detenga.

Tests

Escribe tests para tu bot. Esto se puede hacer con grammY así

  1. Simular las peticiones salientes de la API utilizando funciones de transformación.
  2. Define y envía ejemplos de actualización a tu bot via bot.handleUpdate (referencia APIopen in new window). Considere inspirarse en estos ejemplosopen in new window proporcionados por el equipo de Telegram.

Contribuye al framework de testing.

Aunque grammY proporciona lo necesario para empezar a escribir tests, sería muy útil tener un framework para los bots. Este es un territorio novedoso, tales frameworks no existen en gran medida. ¡Esperamos tus contribuciones!.