头图

1. 前言

本文将说明如何在观测云上通过 DataFlux Func 和 Slack 做集成,能够把告警信息及时推送到 Slack 中显示告警相关信息。

1.1 关于 Slack

Slack 是一个流行的协作工具,它提供了一个集中的平台,让团队成员能够通过即时消息、文件共享、搜索和集成第三方服务来沟通和协作。以下是 Slack 的一些关键特点:

  • 即时消息:Slack 允许用户发送一对一或群组消息,支持文本、图片、视频和音频消息。
  • 频道:用户可以创建不同的频道来组织讨论,例如按项目、主题或部门分类。
  • 直接消息:用户可以与团队中的其他成员私下交流。
  • 文件共享:Slack 允许用户在对话中共享文件,包括文档、图片和视频。
  • 搜索功能:强大的搜索功能可以帮助用户快速找到过去的对话或文件。
  • 集成:Slack 可以与许多第三方服务集成,如 Google Drive、Trello、GitHub 等,使得工作流程更加无缝。
  • 自动化:通过使用 Slack 的 API 和机器人,用户可以创建自动化工作流程,例如自动发送消息或执行任务。
  • 安全性:Slack 提供了多种安全措施,包括数据加密、双因素认证等。
  • 移动和桌面应用:Slack 提供了 iOS 和 Android 的移动应用,以及适用于 Windows、macOS 和 Linux 的桌面应用。

总体来说,Slack 旨在提高团队的沟通效率,减少电子邮件的使用,并帮助团队成员更好地协作。它适用于各种规模的团队,从小型创业公司到大型企业。

1.2 观测云和 Slack

观测云可以配置和 Slack 的集成告警,当应用程序或服务出现问题时,自动向 Slack 发送通知。使得相关团队能够快速响应和解决问题。

2. 集成步骤说明

2.1 Slack 的配置说明

2.1.1 创建一个通知渠道

图片

2.1.2 为渠道添加 Incoming WebHook 自定义应用

图片

2.1.3 Incoming WebHook 的配置

在 Incoming Webhook 的配置中查看调用 WebHook 的 URL 和示例

图片

创建完成后会看到如下信息

图片

2.2 DataFlux Func 的配置说明

通过DataFlux Func 和 Slack 的通知渠道做集成。说明如下:

2.2.1 相关代码如下

import requests
import json

events_url = "https://hooks.slack.com/services/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"

@DFF.API('Slack_Webhook_Proxy_API')
def create_slack_message(**event):
    try:
        if event:
            checker_name = event.get("df_monitor_checker_name")
            checker_value = event.get("df_monitor_checker_value")
            severity = event.get("df_status")
            label = event.get("df_label")
            event_link = event.get("df_event_link")
            workspace_name = event.get("df_workspace_name")
            ts = event.get("timestamp")
            headers = {"Content-Type": "application/json"}

            severity_icons = {
                "critical": ":fire:",
                "error": ":no_entry:",
                "warning": ":warning:",
                "ok": ":large_green_circle:"
            }

            color_list = {
                "critical": "#ff0000",
                "error": "#eb9b34",
                "warning": "#e5eb34",
                "ok": "#03fc14"
            }

            icon = severity_icons.get(severity)
            payload_colors = color_list.get(severity)

            severity = severity.upper()

            payload = {
                "attachments": [{
                      "color": f"{payload_colors}",
                      "author_name": f"{icon} {severity}",
                      "title": f"CF Alerts | {workspace_name} workspace",
                      "title_link": f"{event_link}",
                      "text": f"The {checker_name} monitor has triggered a {severity} alert (value: *{checker_value}*) in the {workspace_name} workspace.",
                      "footer": "Time",
                      "ts": f"{ts}"

                }]
            }

            print(payload)
            ## Post to Webhook
            res = requests.post(events_url, headers=headers, data=json.dumps(payload))
            print(res.status_code)

    except Exception as e:
        # 捕获HTTP错误
        print(f"错误发生: {e}")

在 DataFlux Func 中配置同步 API

图片

通过示例查看 API 的调用地址和调用示例:

图片

2.3 观测云上的配置

2.3.1 创建 Webhook 的通知对象

图片

Webhook 的地址为 DataFlux Func 中的 API 调用地址。

2.3.2 创建告警策略

图片

2.3.3 监控器设置

图片

在告警策略中选择前面创建的 slack 策略。

3. 效果展示

当达到告警器阈值后,我们将在 Slack 中及时收到如下的告警信息:

图片

同时,点击如下的链接后,会自动跳转到观测云的事件中查看告警详情。

图片

图片

至此,我们初步完成了观测云通过 DataFlux Func 和 Slack 的集成配置。


观测云
21 声望85 粉丝

云时代的系统可观测平台


引用和评论

0 条评论