Esta é a documentação da Apigee e da Apigee híbrida.
Não há documentação equivalente do
Apigee Edge para esse tópico.
Sintoma
Durante a restauração do Cassandra na Apigee híbrida, é possível encontrar erros nos registros de restauração.
Mensagem de erro
Você verá uma das seguintes opções nos registros:
java.net.ConnectException: Connection timed out (Connection timed out)
/tmp/tmp/schema.cql:662:OperationTimedOut: errors={'10.0.0.1': 'Client request timeout. See Session.execute[_async](timeout)'}, last_host=10.0.0.1
/tmp/tmp/schema.cql:6409:AlreadyExists: Table 'kvm_myorg.kvm_map_keys_descriptor' already exists
Causas possíveis
Causa | Descrição | Instruções de solução de problemas aplicáveis para |
---|---|---|
Tempo limite de conexão expirado |
Esse erro é de conectividade entre
pods apigee-cassandra-restore e
apigee-cassandra-default-* .
|
Apigee híbrido |
O tempo limite da operação expirou | Esse erro ocorre quando a restauração expira após 15 minutos. | Apigee híbrido |
Já existe | Essa mensagem de erro não está relacionada à causa do problema e é resultado de uma operação de repetição de um job de restauração. | Apigee híbrido |
Causa: tempo limite de conexão esgotado
O seguinte é um erro de conectividade entre
pods apigee-cassandra-restore
e
apigee-cassandra-default-*
:
java.net.ConnectException: Connection timed out (Connection timed out)
Diagnóstico
-
Se a rede do host não estiver acessível pela rede do pod, verifique se
hostNetwork
está definido comofalse
emcassandra
emoverrides.yaml
, conforme mostrado em Como restaurar uma região a partir de um backup. -
Para testar a conectividade, faça login no pod
apigee-mart
ouapigee-runtime
, que está na mesma rede que o jobapigee-cassandra-restore
. Também é possível usar qualquer outro pod na rede de pods.-
Consiga o nome do pod
apigee-mart
:kubectl -n apigee get po --selector=app=apigee-mart --no-headers -o custom-columns=":metadata.name"
-
Execute uma sessão bash dentro do pod mart:
kubectl exec -it MART_POD_NAME -n apigee -- bash
Substitua MART_POD_NAME pelo nome do pod MART. Por exemplo,
apigee-mart-myorg--9a8228a-191-t0xh1-qz5fl
. -
Execute testes de conectividade nas
portas do Cassandra:
curl -v -m 5 telnet://apigee-cassandra-default-0.apigee-cassandra-default.apigee.svc.cluster.local:9042
curl -v -m 5 telnet://apigee-cassandra-default-0.apigee-cassandra-default.apigee.svc.cluster.local:7001
Se você receber um erro
Connection timed out
na saída, isso significa que há problemas de conectividade. No entanto, se você receber uma mensagemConnected to
, indicando que a conexão foi bem-sucedida, pressione Ctrl + C para fechar a conexão e continuar. -
Consiga o nome do pod
Resolução
Verifique se a configuração HostNetwork
está definida como
false
no arquivo overrides.yaml
usado para restauração
e
repita o processo de restauração. Se a configuração já estiver definida como false
, mas você encontrar erros de conectividade, verifique se os pods do Cassandra estão funcionando com o seguinte comando:
kubectl get pods -n apigee -l app=apigee-cassandra
As saídas terão a aparência do exemplo a seguir:
NAME READY STATUS RESTARTS AGE apigee-cassandra-default-0 1/1 Running 0 14m apigee-cassandra-default-1 1/1 Running 0 13m apigee-cassandra-default-2 1/1 Running 0 11m exampleuser@example hybrid-files %
Causa: tempo limite da operação esgotado
O erro a seguir ocorrerá se a restauração expirar após mais de 15 minutos. O erro indica problemas de E/S, como armazenamento e rede que não conseguem transmitir o conteúdo descompactado do backup a tempo.
/tmp/tmp/schema.cql:662:OperationTimedOut: errors={'10.0.0.1': 'Client request timeout. See Session.execute[_async](timeout)'}, last_host=10.0.0.1
Diagnóstico
-
Verifique os registros
apigee-cassandra-default-0
para observar o carimbo de data/hora do início da restauração:kubectl logs apigee-cassandra-default-0 -n apigee | grep 'MigrationManager.java' | head -n 1
-
Compare o carimbo de data/hora com o registro mais recente da criação da tabela:
kubectl logs apigee-cassandra-default-0 -n apigee | grep 'Create new table' | tail -n 1
Os resultados dessa comparação mostram que o pod do Cassandra ainda estava no processo de criação de tabelas após o tempo limite ter sido excedido.
-
Teste a largura de banda de armazenamento com os seguintes comandos:
kubectl -n apigee exec -it apigee-cassandra-default-0 -- bash -c 'dd if=/dev/zero of=/opt/apigee/data/test.img bs=200M count=1 ; rm /opt/apigee/data/test.img'
kubectl -n apigee exec -it apigee-cassandra-default-1 -- bash -c 'dd if=/dev/zero of=/opt/apigee/data/test.img bs=200M count=1 ; rm /opt/apigee/data/test.img'
kubectl -n apigee exec -it apigee-cassandra-default-2 -- bash -c 'dd if=/dev/zero of=/opt/apigee/data/test.img bs=200M count=1 ; rm /opt/apigee/data/test.img'
Se a velocidade de gravação for inferior a 100 M/s, isso pode indicar a falta de um StorageClass apropriado (SSD) usado.
-
Teste a largura de banda da rede:
-
Execute
netcat
no pod do Cassandra para ouvir na porta:kubectl -n apigee exec -it apigee-cassandra-default-0 -- bash -c 'nc -l -p 3456 > /dev/null'
-
Em uma sessão de shell separada, consiga o nome do pod
apigee-mart
:kubectl -n apigee get po --selector=app=apigee-mart --no-headers -o custom-columns=":metadata.name"
-
Execute uma sessão bash dentro do pod
apigee-mart
. Também é possível usar qualquer outro pod na rede de pods:kubectl exec -it MART_POD_NAME -n apigee -- bash
Substitua MART_POD_NAME pelo nome do pod MART. Por exemplo,
apigee-mart-myorg--9a8228a-191-t0xh1-qz5fl
. -
Execute um teste de largura de banda da rede no pod do Cassandra que ainda está executando o
netcat
:dd if=/dev/zero bs=50M count=1 | nc apigee-cassandra-default-0.apigee-cassandra-default.apigee.svc.cluster.local 3456
Repita o processo para outros pods do Cassandra. Se a velocidade resultante for inferior a 10 M/s, a largura de banda da rede provavelmente será a causa do problema.
-
Resolução
Depois que a velocidade de E/S lenta for confirmada com as etapas acima, verifique se o cluster está em conformidade com os requisitos mínimos de rede e armazenamento. Em seguida, teste a largura de banda novamente.
Causa: já existe
Diagnóstico
Você vai encontrar um erro semelhante ao seguinte:
/tmp/tmp/schema.cql:6409:AlreadyExists: Table 'kvm_myorg.kvm_map_keys_descriptor' already exists
Resolução
Essa mensagem de erro não está relacionada à causa do problema e é resultado de uma operação de repetição de um job de restauração. A mensagem de erro real será exibida nos registros do primeiro pod que falhou.
Consiga os registros da falha inicial para diagnosticar o problema.
Se o problema persistir, acesse Precisa de informações de diagnóstico.
É necessário coletar informações de diagnóstico
Se o problema persistir mesmo depois de seguir as instruções acima, reúna as seguintes informações de diagnóstico e entre em contato com o Suporte da Apigee:
-
Além dos dados usuais que podem ser solicitados, colete os dados de diagnóstico de todos os pods do Cassandra com o seguinte comando:
for p in $(kubectl -n apigee get pods -l app=apigee-cassandra --no-headers -o custom-columns=":metadata.name") ; do \ for com in info describecluster failuredetector version status ring info gossipinfo compactionstats tpstats netstats cfstats proxyhistograms gcstats ; do kubectl \ -n apigee exec ${p} -- bash -c 'nodetool -u $APIGEE_JMX_USER -pw $APIGEE_JMX_PASSWORD '"$com"' 2>&1 '\ | tee /tmp/k_cassandra_nodetool_${com}_${p}_$(date +%Y.%m.%d_%H.%M.%S).txt | head -n 40 ; echo '...' ; done; done
-
Compacte-o e informe-o no caso de suporte:
tar -cvzf /tmp/cassandra_data_$(date +%Y.%m.%d_%H.%M.%S).tar.gz /tmp/k_cassandra_nodetool*
- Colete e forneça os registros do pod de restauração. Os registros são de curta duração, portanto, precisam ser coletados logo após a falha.
- Se você seguiu as etapas de diagnóstico acima, colete todas as saídas do console, copie-as em um arquivo e anexe-o ao caso de suporte.