Administrator documentation
Learn how to administer your GitLab instance (Community Edition and Enterprise Edition). Regular users don't have access to GitLab administration tools and settings.
GitLab has two product distributions: the open source GitLab Community Edition (CE), and the open core GitLab Enterprise Edition (EE), available through different subscriptions.
You can install GitLab CE or GitLab EE, but the features you'll have access to depend on the subscription you choose (Libre, Starter, Premium, or Ultimate). GitLab Community Edition installations only have access to Libre features.
GitLab.com is administered by GitLab, Inc., therefore, only GitLab team members have access to its admin configurations. If you're a GitLab.com user, please check the user documentation.
Installing and maintaining GitLab
Learn how to install, configure, update, and maintain your GitLab instance.
Installing GitLab
-
Install: Requirements, directory structures, and installation methods.
- (Starter/Premium) Database load balancing: Distribute database queries among multiple database servers.
- (Starter/Premium) Omnibus support for external MySQL DB: Omnibus package supports configuring an external MySQL database.
- (Starter/Premium) Omnibus support for log forwarding
-
High Availability: Configure multiple servers for scaling or high availability.
- High Availability on AWS: Set up GitLab HA on Amazon AWS.
- (Premium) Geo: Replicate your GitLab instance to other geographical locations as a read-only fully operational version.
- (Premium) Disaster Recovery: Quickly fail-over to a different site with minimal effort in a disaster situation.
- (Premium) Pivotal Tile: Deploy GitLab as a pre-configured appliance using Ops Manager (BOSH) for Pivotal Cloud Foundry.
Configuring GitLab
- Adjust your instance's timezone: Customize the default time zone of GitLab.
- System hooks: Notifications when users, projects and keys are changed.
- Security: Learn what you can do to further secure your GitLab instance.
- Usage statistics, version check, and usage ping: Enable or disable information about your instance to be sent to GitLab, Inc.
- Polling: Configure how often the GitLab UI polls for updates.
- GitLab Pages configuration: Enable and configure GitLab Pages.
- GitLab Pages configuration for GitLab source installations: Enable and configure GitLab Pages on
- Uploads configuration: Configure GitLab uploads storage. source installations.
- Environment variables: Supported environment variables that can be used to override their defaults values in order to configure GitLab.
- (Starter/Premium) Elasticsearch: Enable Elasticsearch to empower GitLab's Advanced Global Search. Useful when you deal with a huge amount of data.
Customizing GitLab's appearance
- Header logo: Change the logo on all pages and email headers.
- Branded login page: Customize the login page with your own logo, title, and description.
- Welcome message: Add a custom welcome message to the sign-in page.
- "New Project" page: Customize the text to be displayed on the page that opens whenever your users create a new project.
Maintaining GitLab
-
Raketasks: Perform various tasks for maintenance, backups, automatic webhooks setup, etc.
- Backup and restore: Backup and restore your GitLab instance.
- Operations: Keeping GitLab up and running (clean up Redis sessions, moving repositories, Sidekiq Job throttling, Sidekiq MemoryKiller, Unicorn).
- Restart GitLab: Learn how to restart GitLab and its components.
Updating GitLab
- GitLab versions and maintenance policy: Understand GitLab versions and releases (Major, Minor, Patch, Security), as well as update recommendations.
- Update GitLab: Update guides to upgrade your installation to a new version.
- Downtimeless updates: Upgrade to a newer major, minor, or patch version of GitLab without taking your GitLab instance offline.
- Migrate your GitLab CI/CD data to another version of GitLab: If you have an old GitLab installation (older than 8.0), follow this guide to migrate your existing GitLab CI/CD data to another version of GitLab.
Upgrading or downgrading GitLab
- Upgrade from GitLab CE to GitLab EE: learn how to upgrade GitLab Community Edition to GitLab Enterprise Editions.
- Downgrade from GitLab EE to GitLab CE: Learn how to downgrade GitLab Enterprise Editions to Community Edition.
GitLab platform integrations
- Mattermost: Integrate with Mattermost, an open source, private cloud workplace for web messaging.
- PlantUML: Create simple diagrams in AsciiDoc and Markdown documents created in snippets, wikis, and repos.
- Web terminals: Provide terminal access to your applications deployed to Kubernetes from within GitLab's CI/CD environments.
User settings and permissions
- Libravatar: Use Libravatar instead of Gravatar for user avatars.
- Sign-up restrictions: block email addresses of specific domains, or whitelist only specific domains.
- Access restrictions: Define which Git access protocols can be used to talk to GitLab (SSH, HTTP, HTTPS).
-
Authentication/Authorization: Enforce 2FA, configure external authentication with LDAP, SAML, CAS and additional Omniauth providers.
- (Starter/Premium) Sync LDAP
- (Starter/Premium) Kerberos authentication
- (Starter/Premium) Email users: Email GitLab users from within GitLab.
- User Cohorts: Display the monthly cohorts of new users and their activities over time.
- (Starter/Premium) Audit logs and events: View the changes made within the GitLab server.
- (Premium) Auditor users: Users with read-only access to all projects, groups, and other resources on the GitLab instance.
-
Incoming email: Configure incoming emails to allow
users to reply by email, create issues by email and
merge requests by email, and to enable Service Desk.
- Postfix for incoming email: Set up a basic Postfix mail server with IMAP authentication on Ubuntu for incoming emails. server with IMAP authentication on Ubuntu, to be used with Reply by email.
- User Cohorts: Display the monthly cohorts of new users and their activities over time.
Project settings
- Container Registry: Configure Container Registry with GitLab.
- Issue closing pattern: Customize how to close an issue from commit messages.
- Gitaly: Configuring Gitaly, GitLab's Git repository storage service.
- Default labels: Create labels that will be automatically added to every new project.
- Restrict the use of public or internal projects: Restrict the use of visibility levels for users when they create a project or a snippet.
Repository settings
- Repository checks: Periodic Git repository checks.
- Repository storage paths: Manage the paths used to store repositories.
- Repository storage rake tasks: A collection of rake tasks to list and migrate existing projects and attachments associated with it from Legacy storage to Hashed storage.
- (Starter/Premium) Limit repository size: Set a hard limit for your repositories' size.
Continuous Integration settings
- Enable/disable GitLab CI/CD: Enable or disable GitLab CI/CD for your instance.
- GitLab CI/CD admin settings: Define max artifacts size and expiration time.
- Job artifacts: Enable, disable, and configure job artifacts (a set of files and directories which are outputted by a job when it completes successfully).
- Artifacts size and expiration: Define maximum artifacts limits and expiration date.
- Register Shared and specific Runners: Learn how to register and configure Shared and specific Runners to your own instance.
- Shared Runners pipelines quota: Limit the usage of pipeline minutes for Shared Runners.
- Enable/disable Auto DevOps: Enable or disable Auto DevOps for your instance.
Git configuration options
- Custom Git hooks: Custom Git hooks (on the filesystem) for when webhooks aren't enough.
- Git LFS configuration: Learn how to configure LFS for GitLab.
- Housekeeping: Keep your Git repositories tidy and fast.
Monitoring GitLab
-
Monitoring GitLab:
- Monitoring uptime: Check the server status using the health check endpoint.
- IP whitelist: Monitor endpoints that provide health check information when probed.
- Monitoring GitHub imports: GitLab's GitHub Importer displays Prometheus metrics to monitor the health and progress of the importer.
- Conversational Development (ConvDev) Index: Provides an overview of your entire instance's feature usage.
Performance Monitoring
-
GitLab Performance Monitoring:
- Enable Performance Monitoring: Enable GitLab Performance Monitoring.
- GitLab performance monitoring with InfluxDB: Configure GitLab and InfluxDB for measuring performance metrics.
- InfluxDB Schema: Measurements stored in InfluxDB.
- GitLab performance monitoring with Prometheus: Configure GitLab and Prometheus for measuring performance metrics.
- GitLab performance monitoring with Grafana: Configure GitLab to visualize time series metrics through graphs and dashboards.
- Request Profiling: Get a detailed profile on slow requests.
- Performance Bar: Get performance information for the current page.
Troubleshooting
- Debugging tips: Tips to debug problems when things go wrong
- Log system: Where to look for logs.
- Sidekiq Troubleshooting: Debug when Sidekiq appears hung and is not processing jobs.