Compartilhar via


Solucionar problemas de ações de script no Azure HDInsight

Este artigo descreve as etapas de solução de problemas e possíveis soluções para problemas durante a interação com clusters do Azure HDInsight.

Exibição de logs

Você pode usar a interface de usuário da Web do Apache Ambari para exibir as informações registradas pelas ações de script. Se o script falhar durante a criação do cluster, os logs estão na conta de armazenamento padrão do cluster. Esta seção fornece informações sobre como recuperar os logs usando ambas as opções.

Interface do usuário da Web do Apache Ambari

  1. Em um navegador da Web, navegue até https://CLUSTERNAME.azurehdinsight.net, em que CLUSTERNAME é o nome do cluster.

  2. Na barra na parte superior da página, selecione a entrada ops. Uma lista exibe as operações atuais e anteriores realizadas no cluster por meio do Ambari.

    Barra de interface do usuário da Web do Ambari com o item

  3. Localize as entradas com run_customscriptaction na coluna Operações. Essas entradas são criadas quando as ações de script são executadas.

    Operações de ação de script do Apache Ambari.

    Para exibir as saídas STDOUT e STDERR, selecione a entrada run\customscriptaction e faça drill down pelos links. Essa saída é gerada ao executar o script e pode conter informações úteis.

Conta de armazenamento padrão

Se a criação do cluster falhar devido a um erro de script, os logs serão mantidos na conta de armazenamento de cluster.

  • Os logs de armazenamento estão disponíveis em \STORAGE_ACCOUNT_NAME\DEFAULT_CONTAINER_NAME\custom-scriptaction-logs\CLUSTER_NAME\DATE.

    Logs de ações de script.

    Nesse diretório, os logs são organizados separadamente em nó de cabeçalho, nó de trabalho e nó do zookeeper. Veja os exemplos a seguir:

    • Nó de cabeçalho: <ACTIVE-HEADNODE-NAME>.cloudapp.net

    • Nó de trabalho: <ACTIVE-WORKERNODE-NAME>.cloudapp.net

    • Nó do Zookeeper: <ACTIVE-ZOOKEEPERNODE-NAME>.cloudapp.net

  • Todos os stdout e stderr do host correspondente são carregados na conta de armazenamento. Há um output-*.txt e um errors-*.txt para cada ação de script. O arquivo output-*.txt contém informações sobre o URI do script que foi executado no host. O texto a seguir é um exemplo destas informações:

    'Start downloading script locally: ', u'https://hdiconfigactions.blob.core.windows.net/linuxrconfigactionv01/r-installer-v01.sh'
    
  • É possível criar repetidamente um cluster de ação de script com o mesmo nome. Nesse caso, você pode distinguir os logs relevantes com base no nome da pasta DATE. Por exemplo, a estrutura de pastas de um cluster, mycluster, criado em datas diferentes será semelhante às seguintes entradas de log:

    \STORAGE_ACCOUNT_NAME\DEFAULT_CONTAINER_NAME\custom-scriptaction-logs\mycluster\2015-10-04 \STORAGE_ACCOUNT_NAME\DEFAULT_CONTAINER_NAME\custom-scriptaction-logs\mycluster\2015-10-05

  • Se você criar um cluster de ação de script com o mesmo nome no mesmo dia, você poderá usar o prefixo exclusivo para identificar os arquivos de log relevantes.

  • Se você criar um cluster perto de 00h00, meia-noite, é possível que os arquivos de log incluam dois dias. Nesses casos, você verá duas pastas com datas diferentes para o mesmo cluster.

  • Carregar arquivos de log no contêiner padrão pode levar até cinco minutos, especialmente para clusters grandes. Portanto, caso queira acessar os logs, você não deve excluir imediatamente o cluster se uma ação de script falhar.

Ambari Watchdog

Não altere a senha do watchdog Ambari, hdinsightwatchdog, no seu cluster do HDInsight baseado em Linux. A alteração da senha interrompe a capacidade de executar novas ações de script no cluster HDInsight.

Não é possível importar o BlobService de nome

Sintomas. Falha ao executar a ação de script. Um texto semelhante ao seguinte erro é exibido quando você visualiza a operação no Ambari:

Traceback (most recent call list):
  File "/var/lib/ambari-agent/cache/custom_actions/scripts/run_customscriptaction.py", line 21, in <module>
    from azure.storage.blob import BlobService
ImportError: cannot import name BlobService

Causa. Esse erro ocorre se você atualizar o cliente de Armazenamento do Microsoft Azure do Python incluído com o cluster do HDInsight. O HDInsight espera o cliente de Armazenamento do Azure 0.20.0.

Resolução. Para resolver esse erro, conecte-se manualmente a cada nó de cluster usando ssh. Execute o seguinte comando para reinstalar a versão de cliente de armazenamento correta:

sudo pip install azure-storage==0.20.0

Para saber mais sobre como se conectar ao cluster com SSH, confira Conectar ao HDInsight (Apache Hadoop) usando SSH.

O histórico não mostra os scripts usados durante a criação do cluster

Se o cluster tiver sido criado antes de 15 de março de 2016, talvez você não veja uma entrada no histórico de ação de script. Redimensionar o cluster faz com que os scripts apareçam em um histórico de ação de script.

Há duas exceções:

  • O cluster foi criado antes de 1º de setembro de 2015. Esta data é quando as ações de script foram introduzidas. Qualquer cluster criado antes dessa data não poderia ter usado as ações de script para a criação do cluster.

  • Você usou várias ações de script durante a criação do cluster. Ou usou o mesmo nome para vários scripts, ou o mesmo nome e o mesmo URI, mas parâmetros diferentes para vários scripts. Nesses casos, você verá o seguinte erro:

    No new script actions can be run on this cluster because of conflicting script names in existing scripts. Script names provided at cluster creation must be all unique. Existing scripts are run on resize.
    

Próximas etapas

Se você não encontrou seu problema ou não conseguiu resolver seu problema, visite um dos seguintes canais para obter mais suporte:

  • Obtenha respostas de especialistas do Azure por meio do Suporte da Comunidade do Azure.

  • Conecte-se com @AzureSupport – a conta oficial do Microsoft Azure para aprimorar a experiência do cliente. Como se conectar à comunidade do Azure para os recursos certos: respostas, suporte e especialistas.

  • Se precisar de mais ajuda, poderá enviar uma solicitação de suporte do portal do Azure. Selecione Suporte na barra de menus ou abra o hub Ajuda + suporte. Para obter informações mais detalhadas, consulte Como criar uma solicitação de Suporte do Azure. O acesso ao Gerenciamento de assinaturas e ao suporte de cobrança está incluído na sua assinatura do Microsoft Azure, e o suporte técnico é fornecido por meio de um dos Planos de suporte do Azure.