- Prerequisites
- Allow outbound connections from the GitLab instance
- Allow inbound connections from clients to the GitLab instance
- Run a health check for GitLab Duo
Configure GitLab Duo on a GitLab Self-Managed instance
{{< details >}}
- Offering: GitLab Self-Managed
{{< /details >}}
GitLab Duo is powered by large language models (LLMs), with data sent through an AI gateway. To use GitLab Duo on a GitLab Self-Managed instance, you can do either of the following:
- Use the GitLab AI vendor models and the cloud-based AI gateway that’s hosted by GitLab. This is the default option.
- Use GitLab Duo Self-Hosted to self-host the AI gateway, with a supported self-hosted LLM. This option provides full control over your data and security.
{{< alert type=”note” >}}
You must have an Ultimate subscription with the GitLab Duo Enterprise add-on to use GitLab Duo Self-Hosted.
{{< /alert >}}
This page focuses on how to configure a GitLab Self-Managed instance if you’re using the default, GitLab-hosted option.
Prerequisites
- You must ensure both outbound and inbound connectivity exists. Network firewalls can cause lag or delay.
- Silent Mode must not be turned on.
- You must activate your instance with an activation code.
- GitLab Duo requires GitLab 17.2 and later for the best user experience and results. Earlier versions may continue to work, however the experience may be degraded.
GitLab Duo features that are experimental or beta are turned off by default and must be turned on.
Allow outbound connections from the GitLab instance
Check both your outbound and inbound settings:
- Your firewalls and HTTP/S proxy servers must allow outbound connections
to cloud.gitlab.comandcustomers.gitlab.comon port443both withhttps://. These hosts are protected by Cloudflare. Update your firewall settings to allow traffic to all IP addresses in the list of IP ranges Cloudflare publishes.
- To use an HTTP/S proxy, both gitLab_workhorseandgitLab_railsmust have the necessary web proxy environment variables set.
- In multi-node GitLab installations, configure the HTTP/S proxy on all Rails and Sidekiq nodes.
Allow inbound connections from clients to the GitLab instance
- GitLab instances must allow inbound connections from Duo clients (IDEs,
Code Editors, and GitLab Web Frontend) on port 443 with https://andwss://.
- Both HTTP2and the'upgrade'header must be allowed, because GitLab Duo uses both REST and WebSockets.
- Check for restrictions on WebSocket (wss://) traffic towss://gitlab.example.com/-/cableand other.comdomains. Network policy restrictions onwss://traffic can cause issues with some GitLab Duo Chat services. Consider policy updates to allow these services.
- If you use reverse proxies, such as Apache, you might see GitLab Duo Chat connection issues in your logs, like WebSocket connection to …. failures.
To resolve this problem, try editing your Apache proxy settings:
# Enable WebSocket reverse Proxy
# Needs proxy_wstunnel enabled
  RewriteCond %{HTTP:Upgrade} websocket [NC]
  RewriteCond %{HTTP:Connection} upgrade [NC]
  RewriteRule ^/?(.*) "ws://127.0.0.1:8181/$1" [P,L]
Run a health check for GitLab Duo
{{< details >}}
- Status: Beta
{{< /details >}}
{{< history >}}
- Introduced in GitLab 17.3.
- Download health check report added in GitLab 17.5.
{{< /history >}}
You can determine if your instance meets the requirements to use GitLab Duo. When the health check completes, it displays a pass or fail result and the types of issues. If the health check fails any of the tests, users might not be able to use GitLab Duo features in your instance.
This is a beta feature.
Prerequisites:
- You must be an administrator.
To run a health check:
- On the left sidebar, at the bottom, select Admin.
- Select GitLab Duo.
- On the upper-right corner, select Run health check.
- Optional. In GitLab 17.5 and later, after the health check is complete, you can select Download report to save a detailed report of the health check results.
These tests are performed:
| Test | Description | 
|---|---|
| Network | Tests whether your instance can connect to customers.gitlab.comandcloud.gitlab.com.If your instance cannot connect to either destination, ensure that your firewall or proxy server settings allow connection. | 
| Synchronization | Tests whether your subscription: - Has been activated with an activation code and can be synchronized with customers.gitlab.com.- Has correct access credentials. - Has been synchronized recently. If it hasn’t or the access credentials are missing or expired, you can manually synchronize your subscription data. | 
| System exchange | Tests whether Code Suggestions can be used in your instance. If the system exchange assessment fails, users might not be able to use GitLab Duo features. | 
If you are experiencing any issues with the health check for GitLab Duo Self-Hosted, see the troubleshooting section.