2023-02-26 18:08:07 -05:00
---
title: 'Container Registry'
2023-03-03 01:44:11 -05:00
license: 'Apache-2.0'
2024-04-21 09:56:01 -04:00
origin_url: 'https://github.com/go-gitea/gitea/blob/e865de1e9d65dc09797d165a51c8e705d2a86030/docs/content/usage/packages/container.en-us.md'
2023-02-26 18:08:07 -05:00
---
Publish [Open Container Initiative ](https://opencontainers.org/ ) compliant images for your user or organization.
The container registry follows the OCI specs and supports all compatible images like [Docker ](https://www.docker.com/ ) and [Helm Charts ](https://helm.sh/ ).
## Requirements
To work with the Container registry, you can use the tools for your specific image type.
The following examples use the `docker` client.
## Login to the container registry
To push an image or if the image is in a private registry, you have to authenticate:
```shell
docker login forgejo.example.com
```
2023-08-19 11:14:45 -04:00
If you are using 2FA or OAuth use a [personal access token ](../../api-usage/#authentication ) instead of the password.
2023-02-26 18:08:07 -05:00
## Image naming convention
Images must follow this naming convention:
`{registry}/{owner}/{image}`
2024-02-24 15:20:29 -05:00
When building your docker image, using the naming convention above, this looks like:
```shell
# build an image with tag
docker build -t {registry}/{owner}/{image}:{tag} .
# name an existing image with tag
docker tag {some-existing-image}:{tag} {registry}/{owner}/{image}:{tag}
```
2024-05-27 18:21:02 -04:00
where your registry is the domain of your forgejo instance (e.g. forgejo.example.com).
2023-02-26 18:08:07 -05:00
For example, these are all valid image names for the owner `testuser` :
`forgejo.example.com/testuser/myimage`
`forgejo.example.com/testuser/my-image`
`forgejo.example.com/testuser/my/image`
**NOTE:** The registry only supports case-insensitive tag names. So `image:tag` and `image:Tag` get treated as the same image and tag.
## Push an image
Push an image by executing the following command:
```shell
docker push forgejo.example.com/{owner}/{image}:{tag}
```
2023-03-03 01:44:11 -05:00
| Parameter | Description |
| --------- | ----------------------- |
2023-02-26 18:08:07 -05:00
| `owner` | The owner of the image. |
2023-03-03 01:44:11 -05:00
| `image` | The name of the image. |
| `tag` | The tag of the image. |
2023-02-26 18:08:07 -05:00
For example:
```shell
docker push forgejo.example.com/testuser/myimage:latest
```
2023-05-05 13:12:24 -04:00
For more information please check the [docker push ](https://docs.docker.com/engine/reference/commandline/push/ ) documentation page.
2023-02-26 18:08:07 -05:00
## Pull an image
Pull an image by executing the following command:
```shell
docker pull forgejo.example.com/{owner}/{image}:{tag}
```
2023-03-03 01:44:11 -05:00
| Parameter | Description |
| --------- | ----------------------- |
2023-02-26 18:08:07 -05:00
| `owner` | The owner of the image. |
2023-03-03 01:44:11 -05:00
| `image` | The name of the image. |
| `tag` | The tag of the image. |
2023-02-26 18:08:07 -05:00
For example:
```shell
docker pull forgejo.example.com/testuser/myimage:latest
```