Skip to main content

Entender as migrações de Azure DevOps para GitHub

          GitHub Enterprise Importer pode automatizar a migração do Azure DevOps.

Sobre migrações do Azure DevOps Cloud

Você pode usar GitHub Enterprise Importer para migrar repositórios de Azure DevOps para GitHub Enterprise Cloud (GitHub.com ou GHE.com).

Você só pode usar GitHub Enterprise Importer para migrar de Azure DevOps Cloud, não de Azure DevOps Server. Se você atualmente usa Azure DevOps Server e deseja migrar para GitHub, você pode migrar para Azure DevOps Cloud primeiro. Para obter mais informações, consulte Igrate to Azure DevOps no site Azure.

Antes de criar sua conta corporativa no GitHub, decida se sua empresa usará ou não o Enterprise Managed Users. Isso afeta como seus membros se autenticam e como você gerencia identidades e acesso. Consulte Escolher um tipo de empresa para o GitHub Enterprise Cloud.

Para saber mais sobre as diferenças entre GitHub e Azure DevOps, consulte Principais diferenças entre o Azure DevOps e o GitHub.

Suporte para Azure Pipelines e Azure Boards

Tanto Azure Pipelines quanto Azure Boards podem ser totalmente integrados à sua experiência de GitHub. Você pode configurar sua conta corporativa e Azure DevOps para continuar usando esses serviços, ao mesmo tempo em que se beneficia de ter seus repositórios hospedados em GitHub.

Se você quiser migrar Azure Pipelines para GitHub Actions, entre em contato com o gerenciador de contas GitHub.

Dados que são migrados

          GitHub Enterprise Importer atualmente dá suporte à migração dos seguintes dados de repositório de Azure DevOps para GitHub Enterprise Cloud.
  • Origem do Git (incluindo o histórico de commits)
  • Solicitações de pull
  • Histórico de usuários para solicitações de pull
  • Links de itens de trabalho em pull requests
  • Anexos em solicitações de pull
  • Políticas de ramificação para o repositório (políticas de ramificação com escopo de usuário e políticas de ramificação entre repositórios não estão incluídas)

Limitações dos dados migrados

Há limites para o que GitHub Enterprise Importer pode migrar. Alguns são devido a limitações de GitHub, enquanto outros são limitações de GitHub Enterprise Importer si mesmo.

Limitações de GitHub

  •         **Limite de tamanho de 2 GiB para uma única confirmação do Git:** Nenhuma confirmação única em seu repositório Git pode ser maior que 2 GiB. Se algum de seus commits for maior que 2 GiB, você precisará dividi-lo em commits menores, cada um com 2 GiB ou menos.
    
  •         **Limite de 255 bytes para referências do Git:** Nenhuma referência única do Git, comumente conhecida como "ref", pode ter um nome maior que 255 bytes. Normalmente, isso significa que suas referências não podem ter mais de 255 caracteres, mas qualquer caractere que não seja ASCII, como emojis, pode consumir mais de um byte. Se uma das referências do Git for muito grande, retornaremos uma mensagem de erro clara.
    
  •         **Limite de tamanho de arquivo de 100 MiB:** Depois de concluir a migração, nenhum arquivo único no repositório Git poderá ter mais de 100 MiB. Durante a migração do repositório, esse limite é aumentado para 400 MiB. Considere o uso Git LFS para armazenar arquivos grandes.
    

Limitações de GitHub Enterprise Importer

  • Limite de tamanho de 40 GB para um repositório Git (versão prévia pública): este limite de aplica apenas ao código-fonte. Para verificar se o arquivo do repositório está acima do limite, use a ferramenta git-sizer e analise o tamanho total do BLOB na saída. A ferramenta git-sizer também ajuda a identificar possíveis problemas relacionados a arquivos grandes, tamanho de BLOB, tamanho de commit e contagens de árvores que podem afetar as migrações.
  •         **Limite de tamanho de arquivo de 400 MiB:** Ao migrar um repositório com GitHub Enterprise Importer, nenhum arquivo único no repositório Git pode ter mais de 400 MiB. Considere o uso Git LFS para armazenar arquivos grandes.
    
  •         **
            Git LFS objetos não migrados:** O Importer pode migrar repositórios que usam Git LFS, mas os próprios objetos LFS não serão migrados. Eles podem ser enviados para o destino da migração como uma tarefa de acompanhamento após a conclusão da migração.
    
  •         **Funcionalidade de pesquisa de código atrasada:** a reindexação do índice de pesquisa pode levar algumas horas após a migração de um repositório, e as pesquisas de código podem retornar resultados inesperados até que a reindexação seja concluída.
    
  •         **Os conjuntos de regras configurados para sua organização podem causar falha nas migrações**: por exemplo, se você tiver configurado uma regra que exige que os endereços de email dos autores de commits terminem com `@monalisa.cat` e o repositório que você está migrando contém commits que não obedecem a essa regra, sua migração falhará.
    
  •         **O conteúdo do manequim pode não ser pesquisável**: os manequins são usuários de espaço reservado aos quais o conteúdo importado (como problemas, solicitações de pull, comentários, etc.) está associado. Quando você pesquisa conteúdo associado a um manequim, como problemas atribuídos, os problemas podem não ser encontrados. Uma vez que um manequim é recuperado, o conteúdo deve ser acessado através do novo proprietário.