观测云和 Slack 的集成实践

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 相关代码如下

python 复制代码
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 的集成配置。

相关推荐
lemoncat815 小时前
免费开源!Windows笔记本电池管家
监控·笔记本·电池
cyber_两只龙宝2 天前
haproxy--实现能7层负载均衡、基于cookie会话保持、状态页监控的高性能web服务器集群
linux·运维·负载均衡·监控·haproxy·会话保持·高性能集群
程序员羽毛3 天前
🚀 股票量化多策略盯盘哨兵 V3.0.0 涨停板监控+回测+回放+摸鱼全搞定
股票量化·监控·提醒·股票策略
少云清3 天前
【软件测试】9_性能测试实战 _性能测试监控
性能测试·监控
A-刘晨阳4 天前
Prometheus + Grafana + Alertmanager 实现邮件监控告警及配置告警信息
运维·云计算·grafana·prometheus·监控·邮件
盛世宏博北京6 天前
《合规 GB/T 50356:小型档案馆(100㎡)恒温恒湿自动化方案》
监控·档案温湿度
OpsEye6 天前
监控 100 问(五):监控数据的分析与可视化
运维·网络·信息可视化·it·监控·监控系统
玄德公笔记6 天前
Prometheus监控k8s的metric详解(第二版)-01-scrape 指标抓取
kubernetes·k8s·prometheus·监控·metric·scrape·k8s监控
无线图像传输研究探索10 天前
硬盘录像机(NVR)+ 车载设备:车载图传监控解决方案,重塑移动监控新生态
车载系统·监控·无线图传·车载·车载监控·车载图传
A-刘晨阳12 天前
【Linux】Prometheus + Grafana的使用
linux·运维·grafana·prometheus·监控