Como depurar ocorrências em cache remoto para execução remota

Informar um problema Ver código-fonte Nightly · 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

Esta página descreve como verificar a taxa de acertos do cache e como investigar erros de cache no contexto da execução remota.

Esta página pressupõe que você tenha um build e/ou teste que utilize a execução remota e que você queira garantir que está usando o cache remoto.

Como verificar a taxa de ocorrência em cache

Na saída padrão da execução do Bazel, observe a linha INFO que lista processos, que correspondem aproximadamente às ações do Bazel. Essa linha detalha onde a ação foi executada. Procure o rótulo remote, que indica uma ação executada remotamente, linux-sandbox para ações executadas em um sandbox local e outros valores para outras estratégias de execução. Uma ação com resultado proveniente de um cache remoto é exibida como remote cache hit.

Exemplo:

INFO: 11 processes: 6 remote cache hit, 3 internal, 2 remote.

Neste exemplo, houve seis hits de cache remoto e duas ações não tiveram hits de cache e foram executadas remotamente. A terceira parte interna pode ser ignorada. Geralmente, são ações internas pequenas, como a criação de links simbólicos. As ocorrências de cache local não estão incluídas neste resumo. Se você receber 0 processos (ou um número menor do que o esperado), execute bazel clean seguido pelo comando de build/teste.

Solução de problemas de ocorrências em cache

Se você não estiver recebendo a taxa de acertos de cache esperada, faça o seguinte:

Verifique se a nova execução do mesmo comando de build/teste produz ocorrências em cache

  1. Execute os builds e/ou testes que você quer que preencham o cache. Na primeira vez que um novo build é executado em uma pilha específica, não há acertos de cache remoto. Como parte da execução remota, os resultados da ação são armazenados no cache, e uma execução subsequente precisa coletá-los.

  2. Execute bazel clean. Esse comando limpa o cache local, o que permite investigar ocorrências de cache remoto sem que os resultados sejam mascarados por ocorrências de cache local.

  3. Execute as compilações e os testes que você está investigando novamente (na mesma máquina).

  4. Verifique a linha INFO para conferir a taxa de ocorrência em cache. Se não houver nenhum processo, exceto remote cache hit e internal, o cache está sendo preenchido e acessado corretamente. Nesse caso, avance para a próxima seção.

  5. Uma possível fonte de discrepância é algo não hermético no build que faz com que as ações recebam chaves de ação diferentes nas duas execuções. Para encontrar essas ações, faça o seguinte:

    a. Execute novamente os builds ou testes em questão para receber os registros de execução:

      bazel clean
      bazel --optional-flags build //your:target --execution_log_binary_file=/tmp/exec1.log

    b. Compare os registros de execução entre as duas execuções. Verifique se as ações são idênticas nos dois arquivos de registro. As discrepâncias dão uma dica sobre as mudanças que ocorreram entre as execuções. Atualize o build para eliminar essas discrepâncias.

    Se você conseguir resolver os problemas de armazenamento em cache e a execução repetida produzir todas as correspondências de cache, pule para a próxima seção.

    Se os IDs de ação forem idênticos, mas não houver ocorrências em cache, algo na sua configuração está impedindo o armazenamento em cache. Continue com esta seção para verificar se há problemas comuns.

    Se não for necessário diferenciar os registros de execução, use a sinalização --execution_log_json_file legível por humanos. Ele não pode ser usado para comparações estáveis, já que contém tempo de execução e não garante a ordenação.

  6. Verifique se todas as ações no registro de execução têm cacheable definido como verdadeiro. Se cacheable não aparecer no registro de execução de uma determinada ação, significa que a regra correspondente pode ter uma tag no-cache na definição no arquivo BUILD. Observe o campo progress_message legível por humanos no registro de execução para ajudar a determinar de onde a ação está vindo.

  7. Se as ações forem idênticas e cacheable, mas não houver acertos de cache, é possível que a linha de comando inclua --noremote_accept_cached, o que desativaria as pesquisas de cache para um build.

    Se for difícil descobrir a linha de comando real, use a linha de comando canônica do Build Event Protocol da seguinte maneira:

    a. Adicione --build_event_text_file=/tmp/bep.txt ao seu comando Bazel para receber a versão em texto do registro.

    b. Abra a versão em texto do registro e procure a mensagem structured_command_line com command_line_label: "canonical". Ele vai listar todas as opções após a expansão.

    c. Pesquise remote_accept_cached e verifique se ele está definido como false.

    d. Se remote_accept_cached for false, determine onde ele está sendo definido como false: na linha de comando ou em um arquivo bazelrc.

Garantir o armazenamento em cache em várias máquinas

Depois que as correspondências de cache estiverem acontecendo conforme o esperado na mesma máquina, execute os mesmos builds/testes em uma máquina diferente. Se você suspeitar que o armazenamento em cache não está acontecendo em todas as máquinas, faça o seguinte:

  1. Faça uma pequena modificação no build para evitar o uso de caches atuais.

  2. Execute o build na primeira máquina:

     bazel clean
     bazel ... build ... --execution_log_binary_file=/tmp/exec1.log
  3. Execute o build na segunda máquina, garantindo que a modificação da etapa 1 esteja incluída:

     bazel clean
     bazel ... build ... --execution_log_binary_file=/tmp/exec2.log
  4. Compare os registros de execução das duas execuções. Se os registros não forem idênticos, investigue as configurações de build para verificar se há discrepâncias e se as propriedades do ambiente do host estão vazando em um dos builds.

Comparar os registros de execução

Os registros de execução contêm todas as ações executadas durante o build. Para cada ação, há um elemento SpawnExec que contém todas as informações da chave de ação. Portanto, se os registros forem idênticos, as chaves de cache de ação também serão.

Para comparar os registros de duas versões que não estão compartilhando acertos de cache como esperado, faça o seguinte:

  1. Receba os registros de execução de cada build e os armazene como /tmp/exec1.log e /tmp/exec2.log.

  2. Faça o download do código-fonte do Bazel e vá para a pasta do Bazel usando o comando abaixo. Você precisa do código-fonte para analisar os registros de execução com o analisador de execlog.

    git clone https://github.com/bazelbuild/bazel.git
    cd bazel
    
  3. Use o analisador de registros de execução para converter os registros em texto. A invocação a seguir também classifica as ações no segundo registro para corresponder à ordem das ações no primeiro registro para facilitar a comparação.

    bazel build src/tools/execlog:parser
    bazel-bin/src/tools/execlog/parser \
      --log_path=/tmp/exec1.log \
      --log_path=/tmp/exec2.log \
      --output_path=/tmp/exec1.log.txt \
      --output_path=/tmp/exec2.log.txt
    
  4. Use seu texto preferido para comparar /tmp/exec1.log.txt e /tmp/exec2.log.txt.