Publicamos atualizações frequentes em nossa documentação, e a tradução desta página ainda pode estar em andamento. Para obter as informações mais recentes, acesse a documentação em inglês. Se houver problemas com a tradução desta página, entre em contato conosco.

Sobre o GitHub Packages

GitHub Package Registry é um serviço de hospedagem de pacotes de software que permite que você hospede os seus pacotes de software de forma privada ou pública e que você use os pacotes como dependências nos seus projetos.

GitHub Package Registry está disponível com GitHub Free, GitHub Pro, GitHub Free para organizações, GitHub Team, GitHub Enterprise Cloud, GitHub Enterprise Server 2.22, e GitHub One.


O GitHub Package Registry não está disponível para repositórios privados de contas que utilizam planos antigos por-repositório. GitHub Package Registry está disponível com GitHub Free, GitHub Pro, GitHub Free para organizações, GitHub Team, GitHub Enterprise Cloud e GitHub One. Para obter mais informações, consulte "[produtos de GitHub](/articles/github-s-products)

Neste artigo

Did this doc help you?

Help us make these docs great!

All GitHub docs are open source. See something that's wrong or unclear? Submit a pull request.

Make a contribution

Ou, learn how to contribute.

Sobre o GitHub Package Registry

GitHub Package Registry is a package hosting service, fully integrated with GitHub. O GitHub Package Registry combina seu código-fonte e pacotes em um só lugar para fornecer gerenciamento integrado de permissões e cobrança, para poder centralizar o desenvolvimento do seu software no GitHub.

Você pode integrar GitHub Package Registry com as APIs de GitHub, GitHub Actions e webhooks para criar um fluxo de trabalho de ponta a ponta que inclui as suas soluções de código, CI e implantação.

You can host multiple packages in one repository and see more information about each package by viewing the package's README, download statistics, version history, and more.

When you create a GitHub Actions workflow, you can use the GITHUB_TOKEN to publish and install packages in GitHub Package Registry without needing to store and manage a personal access token. Para obter mais informações, consulte "Sobre GitHub Container Registry."

Nota: GitHub Container Registry está atualmente em versão beta público e sujeito a alterações. Atualmente, GitHub Container Registry é compatível apenas com formatos de imagem do Docker. Durante o beta, o armazenamento e a largura de banda são grátis. Para obter mais informações, consulte "Sobre GitHub Container Registry."

Visualizar pacotes

You can configure webhooks to subscribe to package-related events, such as when a package is published or updated. For more information, see the "package webhook event."

Sobre permissões e visibilidade de pacotes

Registros de pacotesGitHub Container Registry
Locais de hospedagemVocê pode hospedar vários pacotes em um só repositório.Você pode hospedar várias imagens de contêiner em uma organização ou conta de usuário.
PermissõesVocê pode publicar pacotes em um repositório público (pacotes públicos) para compartilhar com {% if currentVersion == "free-pro-team@latest" %}tudo de {% data variables.product.prodname_dotcom %}{% else %}todos na sua instância{% endif %}, ou em um repositório privado (pacotes privados) para compartilhar com os colaboradores ou uma organização. You can use GitHub roles and teams to limit who can install or publish each package, as packages inherit the permissions of the repository. Anyone with read permissions for a repository can install a package as a dependency in a project, and anyone with write permissions can publish a new package version.Para cada imagem de container, você pode escolher o nível de acesso que os outros têm. As permissões para acesso a imagens do contêiner são separadas da sua organização e das permissões do repositório.
VisibilidadeVocê pode publicar pacotes em um repositório público (pacotes públicos) para compartilhar com tudo de GitHub, ou em um repositório privado (pacotes privados) para compartilhar com os colaboradores ou uma organização.Você pode definir a visibilidade de cada uma de suas imagens de contêiner. Uma imagem privada de contêiner só é visível para pessoas e equipes às quais é fornecido acesso na sua organização. Qualquer pessoa pode ver uma imagem pública de contêiner.

Para obter mais informações sobre permissões e visibilidade para GitHub Container Registry, consulte "Configurar controle de acesso e visibilidade para contêineres".

Sobre a cobrança do GitHub Package Registry

O uso de GitHub Package Registry é gratuito para pacotes públicos. Para pacotes privados, cada conta GitHub recebe uma certa quantidade de armazenamento gratuito e transferência de dados, dependendo do produto usado com a conta. Por padrão, a sua conta terá um limite de gastos de $0, que impede o uso adicional de armazenamento ou transferência de dados após atingir o valor incluído. Se você aumentar seu limite de gastos acima do padrão de $0, você será cobrado por qualquer armazenamento adicional ou transferência de dados, também chamado de excedentes, até seu limite de gastos. Quaisquer cupons em sua conta não se aplicam a excedentes de GitHub Package Registry. Para obter mais informações, consulte "Sobre a cobrança do GitHub Package Registry".

Atualização de cobrança para armazenamento de imagem contêiner: Durante a fase beta de GitHub Container Registry, o armazenamento de imagem do Docker e a largura de banda são grátis para os serviços de hospedagem antigo docker. kg.github.com e novo ghcr.io. Para obter mais informações, consulte "Sobre GitHub Container Registry."

Clientes e formatos compatíveis

O GitHub Package Registry usa os comandos nativos de ferramentas de pacotes com os quais você já está familiarizado para publicar e instalar versões de pacote.

Suporte para GitHub Container Registry

O GitHub Container Registry hospeda contêineres em ghcr.io/OWNER/IMAGE-NAME.

Cliente do pacoteLinguagemFormato do pacoteDescrição
arquivo DockerN/Aarquivo DockerPlataforma de gerenciamento de contêiner Docker

Para mais informações sobre o suporte do contêiner oferecido por

GitHub Container Registry, consulte "Sobre GitHub Container Registry.

Suporte para registros de pacotes

Os registros do pacote usam PACKAGE-TYPE.pkg.github.com/OWNER/REPOSITORY/IMAGE-NAME como a URL do host do pacote, substituindo PACKAGE-TYPE pelo espaço de nome do pacote. Por exemplo, o seu Gemfile será hospedado em rubygem.pkg.github.com/OWNER/REPOSITORY/IMAGE-NAME.

LinguagemDescriçãoFormato do pacoteCliente do pacoteEspaço de nome do pacote
JavaScriptGerenciador de pacotes de nópackage.jsonnpmnpm.pkg.github.com/OWNER/REPOSITORY/IMAGE-NAME
RubyGerenciador de pacotes de RubyGemsGemfilegemrubygems.pkg.github.com/OWNER/REPOSITORY/IMAGE-NAME
JavaFerramenta de gerenciamento de projetos e compreensão do Apache Mavenpom.xmlmvnmaven.HOSTNAME/OWNER/REPOSITORY/IMAGE-NAME
JavaFerramenta de automação do build Gradle para Javabuild.gradle ou build.gradle.ktsgradlemaven.HOSTNAME/OWNER/REPOSITORY/IMAGE-NAME
.NETGerenciamento de pacotes NuGet para .NETnupkgdotnet CLInuget.pkg.github.com/OWNER/REPOSITORY/IMAGE-NAME`

Para obter mais informações sobre como configurar o seu cliente de pacote para ser usado com GitHub Package Registry, consulte "Usando o GitHub Package Registry com o ecossistema do seu projeto."

Autenticar-se no GitHub Package Registry

Você precisa de um token de acesso para publicar, instalar e excluir pacotes no GitHub Package Registry. Você pode usar um token de acesso pessoal para autenticar com seu nome de usuário diretamente no GitHub Package Registry ou na API GitHub. Ao criar um token de acesso pessoal, você pode atribuir diferentes escopos de token, dependendo da sua necessidade.

Para efetuar a autenticação usando um fluxo de trabalho do GitHub Actions:

  • Para registros de pacotes (PACKAGE-REGISTRY.pkg.github.com/OWNER/REPOSITORY/IMAGE-NAME), você pode usar um GITHUB_TOKEN.
  • Para o registro do contêiner (ghcr.io/OWNER/IMAGE-NAME), você deve usar um token de acesso pessoal.

About tokens

EscopoDescrição
read:packagesFaça o download e instale as imagens de contêiner de GitHub Container Registry
write:packagesFaça o upload e publique as imagens do contêiner para GitHub Container Registry
delete:packagesExclua versões especificadas de imagens privadas ou públicas de contêiner do GitHub Container Registry. Para obter mais informações, consulte "Excluir uma imagem de contêiner".

Para aprender sobre escopos e permissões disponíveis para imagens de contêiner, ver "Sobre GitHub Container Registry" ou "Configurar controle de acesso e visibilidade para imagens de contêiner".

Para obter mais informações, consulte "Criar um token de acesso pessoal" e "Escopos disponíveis".

Sobre escopos e permissões para registros de pacotes

To install or publish a package, you must use a token with the appropriate scope, and your user account must have appropriate permissions for that repository.

Por exemplo:

  • Para fazer o download e instalar pacotes a partir de um repositório, seu token deve ter o escopo read:packages, e sua conta de usuário deve ter permissões de leitura para o repositório. Se o repositório for privado, seu token também deve ter o escopo repo.
  • Para excluir uma versão especificada de um pacote privado no GitHub, seu token deve ter o escopo delete:packages e repo. Não é possível excluir pacotes públicos. Para obter mais informações, consulte "Excluir um pacote".
EscopoDescriçãoPermissões do repositório
read:packagesFaça o download e instale pacotes do GitHub Package Registryleitura
write:packagesFaça o upload e publique os pacotes em GitHub Package Registrygravação
delete:packagesExcluir versões especificadas de pacotes privados de GitHub Package Registryadministrador
repoInstalar, fazer upload e excluir certos pacotes em repositórios privados (junto com read:packages, write:packages, ou delete:packages)leitura, gravação ou administrador

Ao criar um fluxo de trabalho de GitHub Actions, você pode usar o GITHUB_TOKEN para publicar e instalar pacotes no GitHub Package Registry sem precisar armazenar e gerenciar um token de acesso pessoal.

Para obter mais informações, consulte:

Gerenciar pacotes

Você pode excluir uma versão de um pacote privado em GitHub ou usar a API do GraphQL. Ao usar a API do GraphQL para consultar e excluir pacotes privados, você deve usar o mesmo token que você usa para efetuar a autenticação no GitHub Package Registry. Para obter mais informações, consulte "Excluir um pacote" e "Formando chamadas com GraphQL".

Você pode configurar webhooks para assinar eventos relacionados aos pacotes, como quando um pacote é publicado ou atualizado. Para obter mais informações, consulte o evento de webhook de "pacote".

Entrar em contato com o suporte

Se você tiver feedback ou pedidos de recursos para GitHub Package Registry, use o formulário de feedback para GitHub Package Registry.

Entre em contato com Suporte do GitHub sobre GitHub Package Registry usando o nosso formulário de contato se:

  • Você encontrar qualquer coisa que contradiga a documentação
  • Você encontra erros vagos ou pouco claros
  • Seu pacote publicado contém dados confidenciais, como violações do RGPD, chaves API ou informações de identificação pessoal

Did this doc help you?

Help us make these docs great!

All GitHub docs are open source. See something that's wrong or unclear? Submit a pull request.

Make a contribution

Ou, learn how to contribute.