Você pode implantar o GitHub Enterprise Server no Azure global ou Azure Government.
Pré-requisitos
- Você deve ter um GitHub Enterprise arquivo de licença. Para baixar um arquivo de licença existente ou solicitar uma licença de teste, visite enterprise.github.com. Para obter mais informações, consulte "Managing your GitHub Enterprise license."
- Você deve ter uma conta do Azure que permita provisionar novas máquinas. Para obter mais informações, consulte o site do Microsoft Azure.
- A maioria das ações necessárias para iniciar sua máquina virtual (VM) também pode ser executada pelo Portal do Azure. No entanto, é recomendável instalar a interface da linha de comando (CLI) do Azure para a configuração inicial. Veja abaixo alguns exemplos de uso da CLI do Azure 2.0. Para obter mais informações, consulte o guia "Instalar a CLI do Azure 2.0".
Considerações de hardware
GitHub Enterprise Server requer um disco de dados persistente separado do disco raiz. Para obter mais informações, consulte "System overview." Recomendamos diferentes configurações de hardware com base no número de licenças de usuário usadas em sua instância do GitHub Enterprise Server. |
Licenças de usuário | vCPUs | Memória | Armazenamento anexado | Armazenamento raiz |
---|---|---|---|---|
Teste, demonstração ou 10 usuários leves | 2 | 16 GB | 100 GB | 200 GB |
10-3000 | 4 | 32 GB | 250 GB | 200 GB |
3000-5000 | 8 | 64 GB | 500 GB | 200 GB |
5000-8000 | 12 | 96 GB | 750 GB | 200 GB |
8000-10000+ | 16 | 128 GB | 1000 GB | 200 GB |
Essas são as recomendações mínimas. Podem ser necessários mais recursos, dependendo do seu uso, como atividade do usuário e integrações selecionadas. Ao aumentar os recursos da CPU, é recomendado adicionar pelo menos 6.5 GB de memória para cada CPU (até 16 CPUs) adicionado à sua instância do GitHub Enterprise Server. Para obter mais informações, consulte "Increasing CPU or memory resources."
Nota: O disco raiz pode ser redimensionado construindo um novo appliance ou usando um appliance existente. Para obter mais informações, consulte "Increasing storage capacity."
Aviso: Recomendamos que você use webhooks para buscar alterações de repositório para integração contínua (CI) ou sistemas similares. Verificações automáticas regulares, ou polling, reduzirão significativamente a escalabilidade de sua instância. Para obter mais informações, consulte "Sobre webhooks"
Determinar o tipo de máquina virtual
Antes de iniciar a sua instância do GitHub Enterprise Server no Azure, você terá que determinar o tipo de máquina virtual que melhor se adapta às demandas da sua organização.
Regiões e tipos de VM compatíveis
O appliance do GitHub Enterprise Server requer um disco de dados de armazenamento premium e é compatível com qualquer VM do Azure que tenha suporte ao armazenamento premium. Para obter mais informações, consulte "VMs compatíveis" na documentação do Azure. Para ver informações gerais sobre as VMs disponíveis, consulte a página de visão geral das máquinas virtuais do Azure.
O GitHub Enterprise Server dá suporte a qualquer região compatível com o seu tipo de VM. Para obter mais informações sobre as regiões compatíveis com cada VM, consulte "Produtos disponíveis por região".
Tipos recomendados de VM
É recomendável usar um tipo de instância DS v2 com no mínimo 14 GB de RAM. Você pode usar qualquer tipo de VM compatível. Com base na contagem de licenças de usuário, recomendamos os seguintes tipos de instâncias.
Estações | Tipo recomendado |
---|---|
Teste, demonstração ou 10 usuários leves | Standard_DS11_v2 |
10 - 3000 | Standard_DS12_v2 |
3000 - 8000 | Standard_DS14_v2 |
8000 - 10000+ | Standard_DS15_v2 |
Nota: Você sempre pode ajustar sua CPU ou memória redimensionando sua instância. No entanto, como o redimensionamento da sua CPU ou memória requer tempo de inatividade para os usuários, recomendamos o fornecimento excessivo de recursos para contas em escala.
Criar a instância da máquina virtual do GitHub Enterprise Server
Para criar a instância, você precisará importar a imagem GitHub Enterprise Server para sua máquina virtual e anexar um volume de armazenamento adicional para os dados de sua instância. Para obter mais informações, consulte "Hardware considerations."
-
Localize a imagem mais recente do appliance do GitHub Enterprise Server. Para obter mais informações sobre o comando
vm image list
, consulte "Lista de imagens de vm no az" na documentação da Microsoft.$ az vm image list --all -f GitHub-Enterprise | grep '"urn":' | sort -V
-
Crie uma VM usando a imagem do appliance. Para obter mais informações, consulte "criar vm no az" na documentação da Microsoft.
Veja as opções de nome da VM, grupo de recursos, tamanho da VM, nome da região preferida do Azure, nome da da imagem de VM do appliance que você listou na etapa anterior e o SKU de armazenamento para Premium. Para obter mais informações sobre grupos de recursos, consulte "Grupos de recursos" na documentação da Microsoft.
$ az vm create -n VM_NAME -g RESOURCE_GROUP --size VM_SIZE -l REGION --image APPLIANCE_IMAGE_NAME --storage-sku Premium_LRS
-
Defina as configurações de segurança na VM para abrir as portas necessárias. Para obter mais informações, consulte "abrir portas para a vm no az" na documentação da Microsoft. A tabela abaixo descreve cada porta para determinar quais portas você precisa abrir.
$ az vm open-port -n VM_NAME -g RESOURCE_GROUP --port PORT_NUMBER
Esta tabela identifica o uso de cada porta.
Porta Serviço Descrição 22 SSH Git sobre acesso via SSH. Clone, buscar e fazer push de operações para repositórios público/privado suportados. 25 SMTP Suporte a SMTP com criptografia (STARTTLS). 80 HTTP Acesso ao aplicativo web. Todas as solicitações são redirecionadas para a porta HTTPS quando o SSL estiver habilitado. 122 SSH Exemplo de acesso a shell. A porta SSH padrão (22) é dedicada ao tráfego de rede git+ssh. 161/UDP SNMP Obrigatória para operações de protocolo de monitoramento de rede. 443 HTTPS Aplicativo web e Git sobre acesso HTTPS. 1194/UDP VPN Túnel de rede de réplica segura na configuração de alta disponibilidade. 8080 HTTP Baseado em web de texto simples Console de gerenciamento. Não é necessário, a menos que o SSL seja desativado manualmente. 8443 HTTPS Base segura na web Console de gerenciamento. Necessário para instalação básica e configuração. 9418 Git Porta de protocolo Simples Git. Clonar e buscar somente as operações para repositórios públicos. Comunicação sem criptografia de rede. -
Crie e anexe um novo disco de dados não criptografado à VM e configure o tamanho com base na sua contagem de licenças do usuário. Para obter mais informações, consulte "anexar disco a uma vm no az" na documentação da Microsoft.
Veja as opções de nome da VM (por exemplo,
ghe-acme-corp
), o grupo de recursos, o SKU de armazenamento Premium, o tamanho do disco (por exemplo,100
) e um nome para o VHD resultante.$ az vm disk attach --vm-name VM_NAME -g RESOURCE_GROUP --sku Premium_LRS --new -z SIZE_IN_GB --name ghe-data.vhd --caching ReadWrite
Observação: para que as instâncias não relacionadas à produção tenham capacidade suficiente de E/S, o tamanho mínimo de disco recomendado é de 40 GB com cache de leitura e gravação habilitado (
--caching ReadWrite
).
Configurar a máquina virtual do GitHub Enterprise Server
-
Antes de configurar a VM, você deve aguardar a entrada no status ReadyRole. Verifique o status da VM com o comando
vm list
. Para obter mais informações, consulte "listar vms no az" na documentação da Microsoft.$ az vm list -d -g RESOURCE_GROUP -o table > Name ResourceGroup PowerState PublicIps Fqdns Location Zones > ------ --------------- ------------ ------------ ------- ---------- ------- > VM_NAME RESOURCE_GROUP VM running 40.76.79.202 eastus
Observação: o Azure não cria uma entrada FQDNS automaticamente para a VM. Para obter mais informações, consulte o guia do Azure sobre como "Criar um nome de domínio totalmente qualificado no portal do Azure para uma VM Linux".
-
Copie o nome DNS público da máquina virtual e cole-o em um navegador.
-
No prompt, carregue seu arquivo de licença e defina uma senha de gerenciamento do console. Para obter mais informações, consulte "Managing your GitHub Enterprise license."
-
No Console de gerenciamento, configure e salve as configurações desejadas. Para obter mais informações, consulte "Configurar o appliance do GitHub Enterprise Server".
-
A instância será reiniciada automaticamente.
-
Clique Visit your instance (Visite sua instância).
Leia mais