From cfb1f917832ef658c5730a7a30eaa01f95cab17d Mon Sep 17 00:00:00 2001 From: dat-a-man <98139823+dat-a-man@users.noreply.github.com> Date: Tue, 5 Mar 2024 15:30:01 +0530 Subject: [PATCH] Docs/Updated for slack alerts. (#1042) * Updated for slack alerts. * Updated * Updated with production example * updated * Updated chess production * Updated --- .../docs/examples/chess_production/index.md | 9 ++++++ .../docs/running-in-production/alerting.md | 32 +++++++++++++++++-- 2 files changed, 39 insertions(+), 2 deletions(-) diff --git a/docs/website/docs/examples/chess_production/index.md b/docs/website/docs/examples/chess_production/index.md index d0f87df7d2..ea747288e5 100644 --- a/docs/website/docs/examples/chess_production/index.md +++ b/docs/website/docs/examples/chess_production/index.md @@ -177,6 +177,15 @@ def load_data_with_retry(pipeline, data): ``` +:::warning +To run this example you need to provide Slack incoming hook in `.dlt/secrets.toml`: +```python +[runtime] +slack_incoming_hook="https://hooks.slack.com/services/***" +``` +Read [Using Slack to send messages.](https://dlthub.com/docs/running-in-production/running#using-slack-to-send-messages) +::: + ### Run the pipeline diff --git a/docs/website/docs/running-in-production/alerting.md b/docs/website/docs/running-in-production/alerting.md index 65a9d05eae..2eb787359d 100644 --- a/docs/website/docs/running-in-production/alerting.md +++ b/docs/website/docs/running-in-production/alerting.md @@ -40,5 +40,33 @@ receiving rich information on executed pipelines, including encountered errors a ## Slack -Read [here](./running#using-slack-to-send-messages) about how to send -messages to Slack. +Alerts can be sent to a Slack channel via Slack's incoming webhook URL. The code snippet below demonstrates automated Slack notifications for database table updates using the `send_slack_message` function. + +```python +# Import the send_slack_message function from the dlt library +from dlt.common.runtime.slack import send_slack_message + +# Define the URL for your Slack webhook +hook = "https://hooks.slack.com/services/xxx/xxx/xxx" + +# Iterate over each package in the load_info object +for package in info.load_packages: + # Iterate over each table in the schema_update of the current package + for table_name, table in package.schema_update.items(): + # Iterate over each column in the current table + for column_name, column in table["columns"].items(): + # Send a message to the Slack channel with the table + # and column update information + send_slack_message( + hook, + message=( + f"\tTable updated: {table_name}: " + f"Column changed: {column_name}: " + f"{column['data_type']}" + ) + ) +``` +Refer to this [example](../../docs/examples/chess_production/) for a practical application of the method in a production environment. + +Similarly, Slack notifications can be extended to include information on pipeline execution times, loading durations, schema modifications, and more. For comprehensive details on configuring and sending messages to Slack, please read [here](./running#using-slack-to-send-messages). +