DevOps CMDB平台整合Jira工单

发布于:2024-07-02 ⋅ 阅读:(18) ⋅ 点赞:(0)

背景

在DevOps CMDB平台建设的过程中,我们可以很容易的将业务应用所涉及的云资源(WAF、K8S、虚拟机等)、CICD工具链(Jenkins、ArgoCD)、监控、日志等一次性的维护到CMDB平台,但随着时间的推移,我们却很难及时适应业务应用资源的变化,从而及时有效的更新DevOps CMDB资源。比如某SRE工程师处理完下线某K8S应用的Jira工单后,CMDB平台工程师无法及时知道K8S资源的变化及相关信息,也就无法及时的维护CMDB相关应用。

解决方案

针对上述痛点以及基于Jira工单的DevOps运维背景下,我们可以采用CMDB整合Jira工单的方案来解决CMDB信息维护的问题。具体内容如下:

目标

实现Jira工单处理事件自动同步到CMDB平台及通过邮件、企微消息等通知到CMDB维护人员。

步骤

1 集成Jira和CMDB平台

使用Jira的WebHooks或Jira REST API来监听特定的工单事件(如状态变更、特定字段更新等)。

确保CMDB平台支持API调用或可以通过某种方式接受外部系统的请求。

2 创建Jira WebHook

2.1 登录Jira管理界面

首先,以管理员身份登录到Jira管理界面。

2.2. 导航到WebHook配置页面

点击右上角的齿轮图标,选择 "系统"。

在系统页面左侧的菜单中,找到并点击 "高级" 部分下的 "WebHooks"。

2.3. 创建新的WebHook

在WebHooks页面,点击 "创建WebHook" 按钮。

填写WebHook的基本信息:

名称: 为WebHook指定一个名称,便于识别。

描述: (可选)填写描述信息。

URL: 输入接收WebHook请求的目标URL。

选择事件: 选择触发WebHook的事件类型,可以是某个特定事件(如问题创建、更新、删除等)或多个事件。

例如,选择“Issue Updated”事件来触发WebHook。

配置过滤器(可选):

你可以添加JQL(Jira Query Language)过滤器,以便仅在特定问题匹配条件时触发WebHook。

例如,添加 project = "MYPROJECT" AND status = "Confirmed" 以便仅当特定项目中的问题状态变为“Confirmed”时触发WebHook。

点击 "创建" 按钮,保存WebHook。

示例

以下是一个配置示例,用于在问题更新时触发WebHook,且仅在状态变为“Confirmed”时触发

图片

2.4 接收WebHook的服务

创建WebHook后,确保接收WebHook请求的服务能够处理Jira发送的HTTP请求。以下是一个简单的Flask示例,展示如何接收和处理Jira WebHook请求

图片

2.5 CMDB服务如何处理Jira工单事件

这里可以区分为自动处理、手动处理。

自动处理:操作简单且不需要Jira工单详细信息的事件可以让CMDB平台自动化处理,比如停止应用。

手动处理:操作复杂且需要Jira工单详情的事件,可以在CMDB收到事件后进一步处理,提取工单内容,并以邮件的方式提醒CMDB维护人员,可以设置周期性提醒直到CMDB维护人员处理完CMDB变更后关闭该提醒。

通过上述步骤和代码示例,你可以创建一个接收Jira事件并处理CMDB更新的完整流程,确保CMDB数据的实时性和准确性,同时通知相关团队成员了解更新情况。