-
Notifications
You must be signed in to change notification settings - Fork 3
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
Job runner details #124
base: main
Are you sure you want to change the base?
Job runner details #124
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
# Runner Types | ||
|
||
Metrics are labelled with the runner type. The logic for determining the runner type is as follows - | ||
|
||
If the runner tag is in the [github_hosted_runner_labels](./gh_actions_exporter/config.py) list the runner type will be `github-hosted` else the runner type will be `self-hosted`. Additional `github-hosted` runner tags can be added via config. | ||
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -25,6 +25,7 @@ def __init__(self, settings: Settings): | |
self.job_labelnames = self.common_labelnames.copy() + [ | ||
"job_name", | ||
"runner_type", | ||
"runner_labels", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What kind of query or filter were you trying to do when deciding to add the I see no issue in adding it, just wanna make sure you tried all the options available to you. For example in our org, our self-hosted runners are defined with multiple labels:
And we use the relabel feature to retrieve those value and create new label like:
Which makes it easier for us to query around. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This does look promising. Would you have an example yaml config for achieving the example above? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I do yes, this is an example of what we've been playing with: job_relabelling:
- label: cloud
default: github-hosted
values:
- azure
- aws
type: name # retrieve the info from the runner name (defaults to labels).
- label: image
default: unknown
values:
- ubuntu-latest
- ubuntu-20.04
- ubuntu-22.04
- rocky-8
- redhat-8
- redhat-9
- label: flavor
default: medium # consider github-hosted flavors as medium
values:
- small
- medium
- large
- xlarge And sorry for the lack of documentation on those 😅 , I'll take note on my end and make an effort towards that in the coming days. |
||
] | ||
for relabel in self.settings.job_relabelling: | ||
self.job_labelnames.append(relabel.label) | ||
|
@@ -148,11 +149,14 @@ def workflow_labels(self, webhook: WebHook) -> dict: | |
branch=branch, | ||
event=webhook.workflow_run.event, | ||
) | ||
|
||
def runner_type(self, webhook: WebHook) -> str: | ||
if "self-hosted" in webhook.workflow_job.labels: | ||
return "self-hosted" | ||
return "github-hosted" | ||
if set(webhook.workflow_job.labels) <= set(self.settings.github_hosted_runner_labels): | ||
return "github-hosted" | ||
return "self-hosted" | ||
|
||
def runner_labels(self, webhook: WebHook) -> str: | ||
return ','.join(webhook.workflow_job.labels) | ||
|
||
def relabel_job_labels( | ||
self, relabel: Relabel, labels: List[str] | ||
|
@@ -180,6 +184,7 @@ def job_labels(self, webhook: WebHook, settings: Settings) -> dict: | |
repository_visibility=webhook.repository.visibility, | ||
repository=webhook.repository.full_name, | ||
workflow_name=webhook.workflow_job.workflow_name, | ||
runner_labels=self.runner_labels(webhook), | ||
) | ||
|
||
for relabel in settings.job_relabelling: | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not sure how the doc was rendered (through mkdocs or github), through github at least couldn't get it to redirect unless I go up a couple of folders.
Also added some note for my future self as I was wondering how we could handle GitHub hosted larger runners with this setting.