Obter registos de contentor e eventos no Azure Container Instances
Quando você tiver um contêiner com comportamento incorreto nas Instâncias de Contêiner do Azure, comece exibindo seus logs com logs de contêiner az e transmitindo seu erro padrão e padrão com az container attach. Você também pode exibir logs e eventos para instâncias de contêiner no portal do Azure ou enviar dados de log e eventos para grupos de contêineres para logs do Azure Monitor.
Ver registos
Para exibir logs do código do aplicativo em um contêiner, você pode usar o comando az container logs .
A saída de exemplo a seguir é a saída de log do contêiner baseado em tarefas de exemplo em Definir a linha de comando em uma instância de contêiner, depois de receber uma URL inválida usando uma substituição de linha de comando:
az container logs --resource-group myResourceGroup --name mycontainer
Traceback (most recent call last):
File "wordcount.py", line 11, in <module>
urllib.request.urlretrieve (sys.argv[1], "foo.txt")
File "/usr/local/lib/python3.6/urllib/request.py", line 248, in urlretrieve
with contextlib.closing(urlopen(url, data)) as fp:
File "/usr/local/lib/python3.6/urllib/request.py", line 223, in urlopen
return opener.open(url, data, timeout)
File "/usr/local/lib/python3.6/urllib/request.py", line 532, in open
response = meth(req, response)
File "/usr/local/lib/python3.6/urllib/request.py", line 642, in http_response
'http', request, response, code, msg, hdrs)
File "/usr/local/lib/python3.6/urllib/request.py", line 570, in error
return self._call_chain(*args)
File "/usr/local/lib/python3.6/urllib/request.py", line 504, in _call_chain
result = func(*args)
File "/usr/local/lib/python3.6/urllib/request.py", line 650, in http_error_default
raise HTTPError(req.full_url, code, msg, hdrs, fp)
urllib.error.HTTPError: HTTP Error 404: Not Found
Anexar fluxos de saída
O comando az container attach fornece informações de diagnóstico durante a inicialização do contêiner. Quando o contêiner é iniciado, ele transmite STDOUT e STDERR para o console local.
Por exemplo, aqui está a saída do contêiner baseado em tarefa em Definir a linha de comando em uma instância de contêiner, depois de ser fornecida uma URL válida de um arquivo de texto grande para processar:
az container attach --resource-group myResourceGroup --name mycontainer
Container 'mycontainer' is in state 'Unknown'...
Container 'mycontainer' is in state 'Waiting'...
Container 'mycontainer' is in state 'Running'...
(count: 1) (last timestamp: 2019-03-21 19:42:39+00:00) pulling image "mcr.microsoft.com/azuredocs/aci-wordcount:latest"
Container 'mycontainer1' is in state 'Running'...
(count: 1) (last timestamp: 2019-03-21 19:42:39+00:00) pulling image "mcr.microsoft.com/azuredocs/aci-wordcount:latest"
(count: 1) (last timestamp: 2019-03-21 19:42:52+00:00) Successfully pulled image "mcr.microsoft.com/azuredocs/aci-wordcount:latest"
(count: 1) (last timestamp: 2019-03-21 19:42:55+00:00) Created container
(count: 1) (last timestamp: 2019-03-21 19:42:55+00:00) Started container
Start streaming logs:
[('the', 22979),
('I', 20003),
('and', 18373),
('to', 15651),
('of', 15558),
('a', 12500),
('you', 11818),
('my', 10651),
('in', 9707),
('is', 8195)]
Obter eventos de diagnóstico
Se o contêiner não for implantado com êxito, revise as informações de diagnóstico fornecidas pelo provedor de recursos de Instâncias de Contêiner do Azure. Para exibir os eventos do contêiner, execute o comando az container show :
az container show --resource-group myResourceGroup --name mycontainer
A saída inclui as propriedades principais do seu contêiner, juntamente com eventos de implantação (mostrados aqui truncados):
{
"containers": [
{
"command": null,
"environmentVariables": [],
"image": "mcr.microsoft.com/azuredocs/aci-helloworld",
...
"events": [
{
"count": 1,
"firstTimestamp": "2019-03-21T19:46:22+00:00",
"lastTimestamp": "2019-03-21T19:46:22+00:00",
"message": "pulling image \"mcr.microsoft.com/azuredocs/aci-helloworld\"",
"name": "Pulling",
"type": "Normal"
},
{
"count": 1,
"firstTimestamp": "2019-03-21T19:46:28+00:00",
"lastTimestamp": "2019-03-21T19:46:28+00:00",
"message": "Successfully pulled image \"mcr.microsoft.com/azuredocs/aci-helloworld\"",
"name": "Pulled",
"type": "Normal"
},
{
"count": 1,
"firstTimestamp": "2019-03-21T19:46:31+00:00",
"lastTimestamp": "2019-03-21T19:46:31+00:00",
"message": "Created container",
"name": "Created",
"type": "Normal"
},
{
"count": 1,
"firstTimestamp": "2019-03-21T19:46:31+00:00",
"lastTimestamp": "2019-03-21T19:46:31+00:00",
"message": "Started container",
"name": "Started",
"type": "Normal"
}
],
"previousState": null,
"restartCount": 0
},
"name": "mycontainer",
"ports": [
{
"port": 80,
"protocol": null
}
],
...
}
],
...
}
Próximos passos
Saiba como solucionar problemas comuns de contêiner e implantação para Instâncias de Contêiner do Azure.
Saiba como enviar dados de log e eventos para grupos de contêineres para logs do Azure Monitor.