Criar um aplicativo do Serviço de Aplicativo no Azure Arc (versão prévia)
Neste guia de início rápido, você criará um aplicativo do Serviço de Aplicativo para um cluster do Kubernetes habilitado para Azure Arc (versão prévia). Esse cenário dá suporte apenas a aplicativos Linux e você pode usar uma pilha de linguagens internas ou um contêiner personalizado.
Pré-requisitos
Adicionar extensões da CLI do Azure
Inicie o ambiente Bash no Azure Cloud Shell.
Como esses comandos da CLI ainda não fazem parte do conjunto da CLI principal, adicione-os com os comandos a seguir:
az extension add --upgrade --yes --name customlocation
az extension remove --name appservice-kube
az extension add --upgrade --yes --name appservice-kube
1. Criar um grupo de recursos
Execute o comando a seguir.
az group create --name myResourceGroup --location eastus
2. Obter um local personalizado
Obtenha as seguintes informações sobre o local personalizado do administrador do cluster (consulte Criar um local personalizado).
customLocationGroup="<resource-group-containing-custom-location>"
customLocationName="<name-of-custom-location>"
Obtenha a ID de localização personalizada para a próxima etapa.
customLocationId=$(az customlocation show \
--resource-group $customLocationGroup \
--name $customLocationName \
--query id \
--output tsv)
3. Criar um aplicativo
O exemplo a seguir cria um aplicativo Node.js. Substitua <app-name>
por um nome que seja exclusivo no cluster (os caracteres válidos são a-z
, 0-9
e -
).
Runtimes com suporte:
Descrição | Valor de runtime da CLI |
---|---|
.NET Core 3.1 | DOTNETCORE|3.1 |
.NET 5.0 | DOTNETCORE|6.0 |
Node JS 12 | NODE|12-lts |
Node JS 14 | NODE|14-lts |
Python 3.6 | PYTHON|3.6 |
Python 3.7 | PYTHON|3.7 |
Python 3.8 | PYTHON|3.8 |
PHP 7.3 | PHP|7.3 |
PHP 7.4 | PHP|7.4 |
Java 8 | JAVA|8-jre8 |
Java 11 | JAVA|11-java11 |
Tomcat 8.5 | TOMCAT|8.5-jre8 |
Tomcat 8.5 | TOMCAT|8.5-java11 |
Tomcat 9.0 | TOMCAT|9.0-jre8 |
Tomcat 9.0 | TOMCAT|9.0-java11 |
az webapp create \
--resource-group myResourceGroup \
--name <app-name> \
--custom-location $customLocationId \
--runtime 'NODE|14-lts'
4. Implantar um código
Observação
az webapp up
não tem suporte durante a versão prévia pública.
Obtenha um aplicativo Node.js de exemplo usando Git e implante-o usando a implantação ZIP. Substitua <app-name>
pelo nome do aplicativo Web.
git clone https://github.com/Azure-Samples/nodejs-docs-hello-world
cd nodejs-docs-hello-world
zip -r package.zip .
az webapp config appsettings set --resource-group myResourceGroup --name <app-name> --settings SCM_DO_BUILD_DURING_DEPLOYMENT=true
az webapp deploy --resource-group myResourceGroup --name <app-name> --src-path package.zip
5. Obter logs de diagnóstico usando o Log Analytics
Observação
Para usar o Log Analytics, é preciso ter habilitado-o anteriormente ao instalar a extensão do Serviço de Aplicativo. Se você instalou a extensão sem o Log Analytics, ignore esta etapa.
Navegue até o workspace do Log Analytics configurado com a extensão do Serviço de Aplicativo e clique em Logs no painel de navegação esquerdo. Execute a consulta de exemplo a seguir para mostrar logs das últimas 72 horas. Substitua <app-name>
pelo nome do aplicativo Web. Em caso de erro ao executar uma consulta, tente novamente em 10 a 15 minutos (pode haver um atraso para o Log Analytics começar a receber os logs do aplicativo).
let StartTime = ago(72h);
let EndTime = now();
AppServiceConsoleLogs_CL
| where TimeGenerated between (StartTime .. EndTime)
| where AppName_s =~ "<app-name>"
Os logs do aplicativo para todos os aplicativos hospedados no cluster do Kubernetes são registrados no workspace do Log Analytics, na tabela de log personalizada chamada AppServiceConsoleLogs_CL
.
Log_s contém logs do aplicativo para um determinado Serviço de Aplicativo e AppName_s contém o nome do aplicativo do Serviço de Aplicativo. Além dos logs que você escreve por meio do código do aplicativo, a coluna Log_s também contém logs sobre inicialização, desligamento e Aplicativos de Funções do contêiner.
Você pode saber mais sobre consultas de log em Introdução ao Kusto.
(Opcional) Implantar um contêiner personalizado
Para criar um aplicativo conteinerizado personalizado, execute az webapp create com --deployment-container-image-name
. Para um repositório privado, adicione --docker-registry-server-user
e --docker-registry-server-password
.
Por exemplo, tente:
az webapp create \
--resource-group myResourceGroup \
--name <app-name> \
--custom-location $customLocationId \
--deployment-container-image-name mcr.microsoft.com/appsvc/staticsite:latest
Para atualizar a imagem após a criação do aplicativo, confira Alterar a imagem Docker de um contêiner personalizado