Skip to main content

An extension for the discord.py library that enables Prometheus metrics

Project description

discord-ext-prometheus

PyPi Version PyPI Python Version License MIT Grafana Dashboard Downloads

This is a library that makes it easy to add prometheus metrics to your Python Discord bot.

Installation

pip install discord-ext-prometheus

Exposed Metrics

Name Documentation Labels
discord_connected Determines if the bot is connected to Discord shard
discord_latency Latency to Discord shard
discord_event_on_interaction Amount of interactions called by users shard, interaction, command
discord_event_on_command Amount of commands called by users shard, command
discord_stat_total_guilds Amount of guild this bot is a member of None
discord_stat_total_channels Amount of channels this bot is has access to None
discord_stat_total_users Amount of users this bot can see None
discord_stat_total_commands Amount of commands None
logging Log entries logger, level

Notes:

  • on_interaction are application interactions such as slash commands or modals
  • on_command are traditional message commands (usualy using the command prefix)

Grafana Dashboard

Dashboard Preview

Available to import from Grafana dashboards

How to use

Once the cog is added to your bot, the Prometheus metric endpoint can be accessed at localhost:8000/metrics.

Sample code with the Prometheus Cog

import asyncio
from discord import Intents
from discord.ext import commands
from discord.ext.prometheus import PrometheusCog

async def main():
	bot = commands.Bot(
		command_prefix='!',
		intents=Intents.all(),
	)

	await bot.add_cog(PrometheusCog(bot))

	await bot.start('YOUR TOKEN')

asyncio.run(main())

Sample code with logging metrics

import asyncio
import logging
from discord import Intents
from discord.ext import commands
from discord.ext.prometheus import PrometheusCog, PrometheusLoggingHandler

logging.getLogger().addHandler(PrometheusLoggingHandler())

async def main():
	bot = commands.Bot(
		command_prefix='!',
		intents=Intents.all(),
	)

	await bot.add_cog(PrometheusCog(bot))

	@bot.listen()
	async def on_ready():
		logging.info(f'Logged in as {bot.user.name}#{bot.user.discriminator}')

	logging.info('Starting the bot')
	await bot.start('YOUR TOKEN')

asyncio.run(main())

Change the Prometheus port

The default port is 8000 but can be changed while creating the cog.

await bot.add_cog(PrometheusCog(bot, port=7000))

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

discord_ext_prometheus-0.1.5.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

discord_ext_prometheus-0.1.5-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file discord_ext_prometheus-0.1.5.tar.gz.

File metadata

File hashes

Hashes for discord_ext_prometheus-0.1.5.tar.gz
Algorithm Hash digest
SHA256 031f93b6f50e0430c410c4f91b3940ac563d7a461421064078fded5abe74c9b2
MD5 3ffe6e5e992700f1c40e2c4f26260e8b
BLAKE2b-256 3062614dc7154e8fb2aa457986713e0d41b924f3c795602a5bac19cfbc796335

See more details on using hashes here.

File details

Details for the file discord_ext_prometheus-0.1.5-py3-none-any.whl.

File metadata

File hashes

Hashes for discord_ext_prometheus-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 7a8ffd09c74e91ff8781db1899d86d9cef8112aee87e326583498c95812aad3d
MD5 ff16a075e7e600cc596859cc9407098b
BLAKE2b-256 b66d5eaed1bc5185ca6a62c41ec7bc5b2179be5e100e2a8e5ebff9e0b5a06f23

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page