É possível gravar registros no Cloud Logging de aplicativos PHP usando a biblioteca do Cloud Logging para PHP diretamente.
Antes de começar
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Verifique se a cobrança está ativada para o seu projeto do Google Cloud.
-
Enable the Cloud Logging API.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Verifique se a cobrança está ativada para o seu projeto do Google Cloud.
-
Enable the Cloud Logging API.
Como instalar a biblioteca do Cloud Logging para PHP
A biblioteca do Cloud Logging para PHP oferece um PSR-3 implementação de logger para frameworks da Web em PHP.
Para registros a partir do aplicativo, adicione a biblioteca do Cloud Logging para PHP ao composer.json:
composer require google/cloud-logging
Como criar um registrador PSR-3
Use o código a seguir para criar um registrador PSR-3:
Como ativar a opção de lote
O registrador PSR-3 envia os registros de maneira síncrona. Isso significa que, sempre que você emitir um registro, ele vai adicionar latência de RPC (remote procedure call) à solicitação do usuário. Se você emitir vários registros em uma única solicitação, a latência adicional será significativa. Portanto, o melhor é evitar isso.
O código a seguir cria um registrador PSR-3 que registrará em lote vários registros em uma única chamada RPC:
Por padrão, esse registrador realiza um único processo para fazer registros em lote. No ambiente flexível do App Engine, é possível configurar a biblioteca do Cloud Logging para PHP para uma capacidade ainda maior e menor latência. Para ver detalhes, consulte Como configurar o daemon da geração de registros.
Como configurar a biblioteca do Cloud Logging para PHP
É possível personalizar o comportamento da biblioteca do Cloud Logging para PHP. Consulte o documento de configuração para conferir uma lista das possíveis opções de configuração.
Como usar o registrador PSR-3
Depois de criar o registrador, use-o no seu aplicativo:
Para mais informações sobre a instalação, consulte a documentação da biblioteca do Cloud Logging para PHP (em inglês). Além disso, use o rastreador de problemas (em inglês) para informá-los.
Gravar registros com a biblioteca de cliente do Cloud Logging
Para informações sobre como usar diretamente a biblioteca de cliente do Cloud Logging para PHP, consulte Bibliotecas de cliente do Cloud Logging.
Executar no Google Cloud
Para que um aplicativo grave logs usando a biblioteca do Cloud Logging para PHP, a
conta de serviço do recurso subjacente precisa ter o papel de
gravador de registros (roles/logging.logWriter
) do IAM.
A maioria dos ambientes do Google Cloud configura automaticamente a conta de serviço padrão
para ter esse papel.
App Engine
O Cloud Logging é ativado automaticamente para o App Engine, e a conta de serviço padrão do aplicativo tem as permissões do IAM por padrão para gravar entradas de registro.
Saiba mais em Gravar e visualizar registros.
No entanto, recomendamos usar o registrador PSR-3 porque ele adiciona metadados automaticamente aos registros. Dessa forma, os registros do aplicativo serão correlacionados aos da solicitação.
Como configurar o daemon para o ambiente flexível do App Engine
No ambiente flexível do App Engine, configure a biblioteca do Cloud Logging para PHP a fim de usar um programa de daemon externo e maximizar a capacidade do log e minimizar a latência do aplicativo. Para ativar esse recurso, adicione esta linha à seção runtime_config
em app.yaml
:
Google Kubernetes Engine (GKE)
O GKE concede automaticamente a conta de serviço
o papel do IAM Gravador de registros (roles/logging.logWriter
).
Se você usar a
Federação de identidade da carga de trabalho para o GKE
com essa conta de serviço padrão para permitir que as cargas de trabalho acessem APIs
específicas do Google Cloud, nenhuma configuração adicional será necessária.
No entanto, se você usar a Federação de identidade da carga de trabalho para o GKE com uma
conta de serviço do IAM personalizada, verifique se a conta de serviço
personalizada tem a função de Logs Writer (roles/logging.logWriter
).
Se necessário, também é possível usar o seguinte comando para adicionar o escopo de acesso logging.write
ao criar o cluster:
gcloud container clusters create example-cluster-name \
--scopes https://www.googleapis.com/auth/logging.write
Compute Engine
Ao usar instâncias de VM do Compute Engine, adicione o escopo de acesso cloud-platform
a cada instância. Ao criar uma nova instância por meio do
Console do Google Cloud, faça isso na seção Identidade e acesso à API.
do painel Criar instância. Use a conta de serviço padrão do Compute Engine ou outra de sua escolha e selecione Permitir acesso completo a todas as APIs do Cloud na seção Identidade e acesso à API. Seja qual for o serviço
da conta selecionada, verifique se ela recebeu o
Papel Gravador de registros no IAM e Admin da
console do Google Cloud.
Execute localmente e em outro lugar
Para usar a biblioteca do Cloud Logging para PHP fora do Google Cloud, incluindo a execução da biblioteca na sua própria estação de trabalho, nos computadores do seu data center ou nas instâncias de VM de outro provedor de nuvem, você precisa fornecer o ID do projeto do Google Cloud e as credenciais da conta de serviço adequadas diretamente à biblioteca do Cloud Logging para PHP.
Para contas de serviço atuais, faça o seguinte:
Conceda à conta de serviço o papel do IAM de gravador de registros (
roles/logging.logWriter
). Para mais informações sobre os papéis do IAM, consulte Controle de acesso.
Se você não tiver uma conta de serviço, crie uma. Para informações sobre processo, consulte Criar contas de serviço.
Para informações gerais sobre os métodos que podem ser usados para autenticação, consulte Terminologia: contas de serviço.
Visualize os registros
No console do Google Cloud, acesse a página Análise de registros:
Acessar a Análise de registros
Se você usar a barra de pesquisa para encontrar essa página, selecione o resultado com o subtítulo Logging.
No Explorador de registros, é preciso especificar um ou mais recursos, mas a escolha deles pode não ser óbvia. Veja a seguir algumas dicas para ajudar você a começar:
Se você estiver implantando seu aplicativo no App Engine ou usando as bibliotecas específicas dele, defina seu recurso como Aplicativo do GAE.
Se você estiver implantando seu aplicativo no Compute Engine, defina o recurso como Instância de VM do GCE.
Se você estiver implantando seu aplicativo no Google Kubernetes Engine, a configuração de geração de registros do cluster determinará o tipo de recurso das entradas de registro. Para um discussão sobre a observabilidade do Google Cloud legado e a observabilidade soluções do Kubernetes Monitoring e como elas afetam tipo de recurso, consulte Como migrar para o Google Cloud Observability Kubernetes Monitoring (em inglês).
Se o aplicativo estiver usando a API Cloud Logging diretamente, o recurso dependerá da API e da configuração. Por exemplo, no seu aplicativo, é possível especificar um recurso ou usar um recurso padrão.
Se você não vir registros no Explorador de registros, alterne para o modo de consulta avançada e use uma consulta vazia para ver todas as entradas de registro.
- Se quiser alternar para o modo de consulta avançada, clique no menu (▾) na parte superior do Explorador de registros e selecione Converter para filtro avançado.
- Limpe o conteúdo que aparece na caixa de filtro.
- Clique em Enviar filtro.
É possível examinar as entradas individuais para identificar seus recursos.
Para mais informações, consulte Como usar a Análise de registros.