GitLab self monitoring project

  • Introduced in GitLab 12.7, behind a disabled feature flag (self_monitoring_project).
  • The feature flag was removed and the Self Monitoring Project was made generally available in GitLab 12.8.

GitLab has been adding the ability for administrators to see insights into the health of their GitLab instance. To surface this experience in a native way (similar to how you would interact with an application deployed using GitLab), a base project called "GitLab self monitoring" with internal visibility is added under a group called "GitLab Instance Administrators" specifically created for visualizing and configuring the monitoring of your GitLab instance.

All administrators at the time of creation of the project and group are added as maintainers of the group and project, and as an admin, you can add new members to the group to give them maintainer access to the project.

This project is used to self monitor your GitLab instance. The metrics dashboard of the project shows some basic resource usage charts, such as CPU and memory usage of each server in Omnibus GitLab installations.

You can also use the project to configure your own custom metrics using metrics exposed by the GitLab exporter.

Creating the self monitoring project

  1. Navigate to Admin Area > Settings > Metrics and profiling, and expand the Self monitoring section.
  2. Toggle the Create Project button on.
  3. Once your GitLab instance creates the project, GitLab displays a link to the project in the text above the Create Project toggle. You can also find it under Projects > Your projects.

Deleting the self monitoring project

WARNING: Deleting the self monitoring project removes any changes made to the project. If you create the project again, it's created in its default state.

  1. Navigate to Admin Area > Settings > Metrics and profiling, and expand the Self monitoring section.
  2. Toggle the Create Project button off.
  3. In the confirmation dialog that opens, click Delete project. It can take a few seconds for it to be deleted.
  4. After the project is deleted, GitLab displays a message confirming your action.

Dashboards available in Omnibus GitLab

Omnibus GitLab provides a dashboard that displays CPU and memory usage of each GitLab server. To select the servers to be displayed in the panels, provide a regular expression in the Instance label regex field. The dashboard uses metrics available in Omnibus GitLab installations.

GitLab self monitoring overview dashboard

You can also create your own dashboards.

Connection to Prometheus

The project is automatically configured to connect to the internal Prometheus instance if the Prometheus instance is present (should be the case if GitLab was installed via Omnibus and you haven't disabled it).

If that's not the case or if you have an external Prometheus instance or a customized setup, you should configure it manually.

Taking action on Prometheus alerts (ULTIMATE)

You can add a webhook to the Prometheus configuration for GitLab to receive notifications of any alerts.

Once the webhook is setup, you can take action on incoming alerts.

Adding custom metrics to the self monitoring project

You can add custom metrics in the self monitoring project by:

  1. Duplicating the overview dashboard.
  2. Editing the newly created dashboard file and configuring it with dashboard YAML properties.

Troubleshooting

Getting error message in logs: Could not create instance administrators group. Errors: ["You don’t have permission to create groups."]

There is a bug which causes project creation to fail with the following error (which appears in the log file) when the first admin user is an external user:

Could not create instance administrators group. Errors: ["You don’t have permission to create groups."]

Run the following in a Rails console to check if the first admin user is an external user:

User.admins.active.first.external?

If this returns true, the first admin user is an external user.

If you face this issue, you can temporarily make the admin user a non-external user and then try to create the project. Once the project is created, the admin user can be changed back to an external user.