Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add alert documentation #63

Merged
merged 5 commits into from
Aug 1, 2024
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 26 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
grafana-docs-monitoring
Eyes-On-Docs
=======================
***********************
YustinaKvr marked this conversation as resolved.
Show resolved Hide resolved
Scripts gathering HC3.0 PRs, issues and docs info from Github and Gitea. Scripts are works both for OTC and Swiss clouds in a one run. Data store in three Postgres databases: **_CSV_** is for a service tables and open PRs, failed Zuul PRs, issues and commits updates, **_ORPH_** is a dedicated DB special for orphan PRs

1) **otc_services_dict.py:** service script gathering metadata for service, its full names, categories and types. Should be run first, since all of the following scripts are relay on it in terms of repo names, service titles and squad names.
Expand All @@ -10,3 +11,27 @@ Scripts gathering HC3.0 PRs, issues and docs info from Github and Gitea. Scripts
6) **last_commit_info.py:** this script gather and calculate date of the last update of a prospective doc for all the services and types of docs (user manual, API reference and so on)
7) **scheduler.py:** this script checking postgres for orphans, unattended issues and outdated docs, and send notifications to Zulip, via OTC Bot. Runs as cronjob (see 'system-config' repo)
Postgres database names, table names, Gitea & Github organization names and access tokens are store in environment variables.

Notification schedule
----------------
****************
YustinaKvr marked this conversation as resolved.
Show resolved Hide resolved
We have 3 types of alerts: Orphaned PRs Count, Unattended Issues and Outdated Documentation Release Dates.\
**Orphaned PRs Count** checks comes every day.\
**Unattended Issues** appears after issues remain unassigned for 7 days.\
**Outdated Documentation Release Date** has more co,plex schedule:
First alert triggers once 3 weeks prior 365 days threshold; second alert triggers once 2 weeks prior, third alert will trigger 1 week prior reaching 365 days threshold. After breaching 1-year threshold, notifications will be delivered daily.

All notifications are delivering to a corresponding channel at 11:00 in a morning.

Notification anatomy
--------------------
********************
This is how typical notification looks like. Since notifications do not differ in their structure, we can give an example of one of them.

![Notification anatomy](https://github.com/opentelekomcloud-infra/grafana-docs-monitoring/blob/documentation/alert_anatomy.PNG)

**Alert name:** name of an alert. Could be *Orphaned PRs Alert,* *Outdated Documents Alert* or *Open Issues Alert.*\
**Alert summary:** what happened, what is this alert about.\
**Squad and Service names, Zone name:** squad and service name to which alert is dedicated to. Zone name could be *Public* for common OTC and *Hybrid* for Swiss Cloud.\
**Direct link to problematic resource:** clickable link points to a resource which state triggert alert - specific commit, or PR or issue.\
**Link leads to Grafana dashboard:** URL points to Grafana dashboard contains briefly info regarding issues, PRs or documents.\
Binary file added alert_anatomy.PNG
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.