# 流水线监控 监听新 projId,自动补全内容,获取从 20240101 到当前的所有流水线信息 监听功能未知原因不好用,先不做了,改手动遍历了 拿到 project_id 后,获取数据表中最新的 pipeline 的 Id,然后比对接口中的 ID 进行填充 如果没有 pipeline 的 id,直接从接口中获取 20240101 到当前的流水线信息 先从数据中获取用户信息填充,随后在根据填充完的用户信息获取全部的 userid 的列表,再写 pipeline 表 # 流水线成功提醒 接收Gitlab 的 WebHooks请求,Secret 令牌 实际上为 Egg 的 API_KEY 获取对应的MR信息,MR 的发起者也需要发送通知 组织卡片信息,给 Commit的用户以及 可能的 MR发起者发送通知 ## 处理在中间Stage需要提醒的情况 ~~在stage全部成功的情况下,按finish_at时间排序,找到最后一个stage,如果stage的状态是成功,且该build的id没有发送过通知,则发送通知~~ 流水线通知只是在Pipeline纬度上,所以某个stage的变化不会触发通知 在流水线为`running`时,如果需要监听Stage,且该stage全部的job有非结束状态时即`created`、`pending`、`running`、`manual`、`scheduled`时 加入数据库监控列表,每10s检查一次,如果stage状态全部成功的时候则发送通知,并删除监控 在流水线结束,即状态为`failed`、`canceled`、`skipped`、`success`,的时候,删除监控,并在状态为`success`的时候,发送通知 # 数据库表信息 [数据库地址](https://gitlab-pb.xiaomiwh.cn/_/) project 信息 ```js { id: 'aaa', project_id: 131366, description: "场景复现平台-展示设备(移动、音箱、小爱建议、车载、手表等设备)上小爱执行结果及相关处理流程", name: "ai-scene-review-fe", path_with_namespace: "miai-fe/fe/ai-scene-review-fe", web_url: "https://git.n.xiaomi.com/miai-fe/fe/ai-scene-review-fe", avatar_url: null, has_new_cicd: false, } ``` pipeline 信息 ```js { id: 'bbb', project_id: 'aaa', user_id: 'ccc', pipeline_id: 7646046, ref: "preview", status: "success", web_url: "https://git.n.xiaomi.com/miai-fe/fe/ai-scene-review-fe/-/pipelines/7646046", started_at: "2024-03-01T16:47:40.192+08:00", finished_at: "2024-03-01T16:49:30.624+08:00", duration: 100, queued_duration: 6, } ``` user 信息 ```js { id: 'ccc', user_id: 10011, username: "zhaoyingbo", name: "赵英博", avatar_url: "https://git.n.xiaomi.com/uploads/-/system/user/avatar/10011/avatar.png", web_url: "https://git.n.xiaomi.com/zhaoyingbo" } ``` 每周每个项目按分支的运行时长统计 SQL `statisticsPerProj` ```SQL SELECT (ROW_NUMBER() OVER()) as id, strftime('%Y-%W', datetime(pip.started_at)) AS week, p.name AS name, ROUND(AVG(pip.duration/60.0), 1) AS duration, pip.ref FROM project p JOIN pipeline pip ON p.id = pip.project_id GROUP BY name, week, pip.ref; ``` 每周流水线运行统计 SQL `statisticsPerWeek` ```SQL SELECT (ROW_NUMBER() OVER()) as id, strftime('%Y-%W', datetime(started_at)) AS week, COUNT(*) AS total_count, SUM(CASE WHEN status = 'success' THEN 0 ELSE 1 END) AS failed_count, SUM(CASE WHEN status = 'success' THEN 1 ELSE 0 END) AS success_count, ROUND(SUM(CASE WHEN status = 'success' THEN 1 ELSE 0 END) * 100.0 / COUNT(*), 1) AS success_rate, ROUND(AVG(duration/60.0), 1) AS duration FROM pipeline GROUP BY week; ``` # GPT 我有一个 sqlite 数据库,表如下 project 表 ```js { id: 'aaa', project_id: 131366, description: "场景复现平台-展示设备(移动、音箱、小爱建议、车载、手表等设备)上小爱执行结果及相关处理流程", name: "ai-scene-review-fe", path_with_namespace: "miai-fe/fe/ai-scene-review-fe", web_url: "https://git.n.xiaomi.com/miai-fe/fe/ai-scene-review-fe", avatar_url: null, has_new_cicd: false, } ``` pipeline 表 ```js { id: 'bbb', project_id: 'aaa', user_id: 'ccc', pipeline_id: 7646046, ref: "preview", status: "success", web_url: "https://git.n.xiaomi.com/miai-fe/fe/ai-scene-review-fe/-/pipelines/7646046", started_at: "2024-03-01T16:47:40.192+08:00", finished_at: "2024-03-01T16:49:30.624+08:00", duration: 100, queued_duration: 6, } ``` user 表 ```js { id: 'ccc', user_id: 10011, username: "zhaoyingbo", name: "赵英博", avatar_url: "https://git.n.xiaomi.com/uploads/-/system/user/avatar/10011/avatar.png", web_url: "https://git.n.xiaomi.com/zhaoyingbo" } ``` 我想按天展示每个项目的 pipeline 按 ref 区分的平均 duration,如何创建视图 # 机器人 ## CICD 统计总结 卡片 ID:ctp_AAyVLS6Q37cL JSON 示例 ```json { "total_count": "29", // OK "group_table": [ { "project_name": "ai-ak-fe", "project_ref": "master", "project_duration": "1.4", "project_duration_rate": "↓12%" }, { "project_name": "ai-class-schedule-fe", "project_ref": "preview", "project_duration": "3.2", "project_duration_rate": "↑5%" }, { "project_name": "ai-scene-review-fe", "project_ref": "staging", "project_duration": "5.4", "project_duration_rate": "↓6%" } ], "weekly_count_rate": "较上周 ↑5%", // OK "weekly_duration_rate": "较上周 ↓12%", // OK "weekly_success_rate": "较上周 ↑12%", // OK "duration": "0.9", // OK "success_rate": "100", // OK "has_new_cicd_count": "15", // OK "without_new_cicd_count": "20" // OK } ``` ## 流水线成功通知 卡片 ID:ctp_AA36QafWyob2 JSON 示例 ```json { "project": "cloudml-visuals/fe/test", "project_link": "https://git.n.xiaomi.com/cloudml-visuals/fe/test", "pipeline": "8815519", "pipeline_link": "https://git.n.xiaomi.com/cloudml-visuals/fe/cloud-ml-fe/-/pipelines", "ref": "preview", "ref_link": "https://git.n.xiaomi.com/cloudml-visuals/fe/cloud-ml-fe/-/commits/preview", "commit_user": "赵英博", "duration": "1m35s", "participant": "赵英博、吴婷", "commit_message": "chore: Add .gitlab-ci.yml for printing \"Hello, world!\"", "mr": "cloudml-visuals/fe/cloud-ml-fe!374", "mr_link": "https://git.n.xiaomi.com/cloudml-visuals/fe/cloud-ml-fe/-/merge_requests/374" } ```