type | stage | group | info |
---|---|---|---|
howto |
Fulfillment |
Utilization |
To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments |
Storage usage statistics are available for projects and namespaces. You can use that information to manage storage usage within the applicable quotas.
Statistics include:
- Storage usage across projects in a namespace.
- Storage usage that exceeds the storage quota.
- Available purchased storage.
Prerequisites:
- To view storage usage for a project, you must have at least the Maintainer role for the project or Owner role for the namespace.
- To view storage usage for a namespace, you must have the Owner role for the namespace.
- On the left sidebar, at the top, select Search GitLab ({search}) to find your project or group.
- On the left sidebar, select Settings > Usage Quotas.
- Select the Storage tab.
Select any title to view details. The information on this page is updated every 90 minutes.
If your namespace shows 'Not applicable.'
, push a commit to any project in the
namespace to recalculate the storage.
Container Registry usage is available only for GitLab.com. This feature requires a new version of the GitLab Container Registry. To learn about the proposed release for self-managed installations, see epic 5521.
Image layers stored in the Container Registry are deduplicated at the root namespace level.
An image is only counted once if:
- You tag the same image more than once in the same repository.
- You tag the same image across distinct repositories under the same root namespace.
An image layer is only counted once if:
- You share the image layer across multiple images in the same container repository, project, or group.
- You share the image layer across different repositories.
Only layers that are referenced by tagged images are accounted for. Untagged images and any layers referenced exclusively by them are subject to online garbage collection. Untagged image layers are automatically deleted after 24 hours if they remain unreferenced during that period.
Image layers are stored on the storage backend in the original (usually compressed) format. This means that the measured size for any given image layer should match the size displayed on the corresponding image manifest.
Namespace usage is refreshed a few minutes after a tag is pushed or deleted from any container repository under the namespace.
It is not possible to calculate container registry usage with maximum precision in real time for extremely large namespaces (about 1% of namespaces). To enable maintainers of these namespaces to see their usage, there is a delayed fallback mechanism. See epic 9413 for more details.
If the usage for a namespace cannot be calculated with precision, GitLab falls back to the delayed method. In the delayed method, the displayed usage size is the sum of all unique image layers in the namespace. Untagged image layers are not ignored. As a result, the displayed usage size might not change significantly after deleting tags. Instead, the size value only changes when:
- An automated garbage collection process runs and deletes untagged image layers. After a user deletes a tag, a garbage collection run is scheduled to start 24 hours later. During that run, images that were previously tagged are analyzed and their layers deleted if not referenced by any other tagged image. If any layers are deleted, the namespace usage is updated.
- The namespace's registry usage shrinks enough that GitLab can measure it with maximum precision. As usage for namespaces shrinks to be under the limits, the measurement switches automatically from delayed to precise usage measurement. There is no place in the UI to determine which measurement method is being used, but issue 386468 proposes to improve this.
- Introduced project-level graph in GitLab 14.4 with a flag named
project_storage_ui
. Disabled by default.- Enabled on GitLab.com in GitLab 14.4.
- Enabled on self-managed in GitLab 14.5.
- Feature flag removed in GitLab 14.5.
The following storage usage statistics are available to a maintainer:
- Total namespace storage used: Total amount of storage used across projects in this namespace.
- Total excess storage used: Total amount of storage used that exceeds their allocated storage.
- Purchased storage available: Total storage that has been purchased but is not yet used.
To manage your storage, if you are a namespace Owner you can purchase more storage for the namespace.
Depending on your role, you can also use the following methods to manage or reduce your storage:
- Reduce package registry storage.
- Reduce dependency proxy storage.
- Reduce repository size.
- Reduce container registry storage.
- Reduce wiki repository size.
Depending on your role, to manage your transfer usage you can reduce Container Registry data transfers.
Projects on GitLab SaaS have a 10 GB storage limit on their Git repository and LFS storage. After namespace-level storage limits are applied, the project limit is removed. A namespace has either a namespace-level storage limit or a project-level storage limit, but not both.
When a project's repository and LFS reaches the quota, the project is set to a read-only state. You cannot push changes to a read-only project. To monitor the size of each repository in a namespace, including a breakdown for each project, view storage usage. To allow a project's repository and LFS to exceed the free quota you must purchase additional storage. For more details, see Excess storage usage.
Excess storage usage is the amount that a project's repository and LFS exceeds the project storage limit. If no purchased storage is available the project is set to a read-only state. You cannot push changes to a read-only project. To remove the read-only state you must purchase more storage for the namespace. When the purchase is completed, read-only projects are automatically restored to their standard state. The amount of purchased storage available must always be greater than zero.
The Storage tab of the Usage Quotas page warns you of the following:
- Purchased storage available is running low.
- Projects that are at risk of becoming read-only if purchased storage available is zero.
- Projects that are read-only because purchased storage available is zero. Read-only projects are marked with an information icon ({information-o}) beside their name.
The following example describes an excess storage scenario for a namespace:
Repository | Storage used | Excess storage | Quota | Status |
---|---|---|---|---|
Red | 10 GB | 0 GB | 10 GB | Read-only {lock} |
Blue | 8 GB | 0 GB | 10 GB | Not read-only |
Green | 10 GB | 0 GB | 10 GB | Read-only {lock} |
Yellow | 2 GB | 0 GB | 10 GB | Not read-only |
Totals | 30 GB | 0 GB | - | - |
The Red and Green projects are read-only because their repositories and LFS have reached the quota. In this example, no additional storage has yet been purchased.
To remove the read-only state from the Red and Green projects, 50 GB additional storage is purchased.
Assuming the Green and Red projects' repositories and LFS grow past the 10 GB quota, the purchased storage available decreases. All projects no longer have the read-only status because 40 GB purchased storage is available: 50 GB (purchased storage) - 10 GB (total excess storage used).
Repository | Storage used | Excess storage | Quota | Status |
---|---|---|---|---|
Red | 15 GB | 5 GB | 10 GB | Not read-only |
Blue | 14 GB | 4 GB | 10 GB | Not read-only |
Green | 11 GB | 1 GB | 10 GB | Not read-only |
Yellow | 5 GB | 0 GB | 10 GB | Not read-only |
Totals | 45 GB | 10 GB | - | - |
Namespaces on GitLab SaaS have a storage limit. For more information, see our pricing page. This limit is not visible on the Usage quotas page, but is prior to the limit being applied. Self-managed deployments are not affected.
Storage types that add to the total namespace storage are:
- Git repository
- Git LFS
- Job artifacts
- Container registry
- Package registry
- Dependency proxy
- Wiki
- Snippets
If your total namespace storage exceeds the available namespace storage quota, all projects under the namespace become read-only. Your ability to write new data is restricted until the read-only state is removed. For more information, see Restricted actions.
To notify you that you have nearly exceeded your namespace storage quota:
- In the command line interface, a notification displays after each
git push
action when you've reached 95% and 100% of your namespace storage quota. - In the GitLab UI, a notification displays when you've reached 75%, 95%, and 100% of your namespace storage quota.
- GitLab sends an email to members with the Owner role to notify them when namespace storage usage is at 70%, 85%, 95%, and 100%.
To prevent exceeding the namespace storage quota, you can:
- Reduce storage consumption by following the suggestions in the Manage Your Storage Usage section of this page.
- Apply for GitLab for Education, GitLab for Open Source, or GitLab for Startups if you meet the eligibility requirements.
- Consider using a self-managed instance of GitLab which does not have these limits on the free tier.
- Purchase additional storage units at $60/year for 10 GB of storage.
- Start a trial or upgrade to GitLab Premium or Ultimate which include higher limits and features that enable growing teams to ship faster without sacrificing on quality.
- Talk to an expert for more information about your options.
Information on when namespace-level storage limits are applied is available on these FAQ pages for the Free and Paid tier.