AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / server / Perguntas / 728727
Accepted
four43
four43
Asked: 2015-10-14 12:40:43 +0800 CST2015-10-14 12:40:43 +0800 CST 2015-10-14 12:40:43 +0800 CST

Kubernetes travado no ContainerCreating

  • 772

Um pod no meu cluster Kubernetes está preso em "ContainerCreating" depois de executar um create. Como vejo os logs dessa operação para diagnosticar por que ela está travada? kubectl logsnão parece funcionar, pois o contêiner precisa estar em um estado não pendente.

kubernetes
  • 5 5 respostas
  • 224089 Views

5 respostas

  • Voted
  1. Best Answer
    Sreekanth Pothanis
    2015-10-22T22:38:09+08:002015-10-22T22:38:09+08:00

    kubectl describe podslistará alguns (provavelmente a maioria, mas não todos) dos eventos associados ao pod, incluindo extração de imagens, inicialização de contêineres.

    • 279
  2. Chris Stryczynski
    2019-12-29T05:36:23+08:002019-12-29T05:36:23+08:00

    Mais informações podem ser fornecidas nos eventos.

    kubectl get events --all-namespaces  --sort-by='.metadata.creationTimestamp'
    

    No entanto, observe que a classificação de eventos pode não funcionar corretamente devido a este bug: https://github.com/kubernetes/kubernetes/issues/29838


    Alternativamente:

    A partir do Kubernetes 1.18, todos os novos objetos têm metadados para aplicação no lado do servidor, o que nos dá uma nova maneira de classificar eventos:

    kubectl get events --sort-by=".metadata.managedFields[0].time"

    De: https://github.com/kubernetes/kubernetes/issues/29838#issuecomment-789660546


    No meu caso, tive um evento relacionado a um pod:

    default       13s         Warning   FailedMount               Pod          Unable to mount volumes for pod "restore-db-123-1-5f24s_default(9b7df264-2976-11ea-bb8f-42010a9a002c)": timeout expired waiting for volumes to attach or mount for pod "default"/"restore-db-123-1-5f24s". list of unmounted volumes=[nfsv]. list of unattached volumes=[nfsv default-token-hxrng]
    
    • 46
  3. Esmailian
    2018-07-10T19:41:41+08:002018-07-10T19:41:41+08:00

    No meu caso, o acesso do docker à internet foi bloqueado. Foi resolvido usando um proxy ( usando o comentário de sandylss ):

    1. minikube stop
    2. minikube delete
    3. export http_proxy=http://user:pass@ip:port
    4. export https_proxy=http://user:pass@ip:port
    5. export no_proxy=192.168.99.0/24
    6. minikube start --logtostderr --v=0 --bootstrapper=localkube --vm-driver hyperv 
        --hyperv-virtual-switch "Primary Virtual Switch" --docker-env HTTP_PROXY=$http_proxy \
        --docker-env HTTPS_PROXY=$https_proxy --docker-env NO_PROXY=$no_proxy
      
    7. export no_proxy=$no_proxy,$(minikube ip)
    8. export NO_PROXY=$no_proxy,$(minikube ip)

    Em seguida, para verificar se o docker tem acesso à internet, execute:

    $ docker pull tutum/hello-world
    

    no cluster (conecte-se ao cluster usando minikube ssh); interrompa o processo se ele iniciar o download.

    Meu segundo problema foi a conexão lenta com a internet. Como as imagens do docker necessárias são da ordem de 100 MB, os contêineres do docker e os pods do Kubernetes permaneceram nos \pauseestados ContainerCreatingpor 30 minutos.

    Para verificar se o docker está baixando as imagens, execute:

    $ ls -l /var/lib/docker/tmp
    

    no cluster, que mostra os arquivos de imagem temporários que estão sendo baixados, caso contrário, vazio.

    Se você estiver desenvolvendo no minikube e usando VPN, o docker pode usar sua VPN via fiddler . Ou seja, o docker será conectado ao ip:port do violinista e o violinista será conectado à VPN. Caso contrário, a VPN não é compartilhada entre seu host e a VM minikube.

    • 6
  4. Luis Felipe Moura Pereira De S
    2019-02-28T10:46:30+08:002019-02-28T10:46:30+08:00

    A única vez que eu bati isso foi porque minhas declarações de recursos foram acidentalmente muito, muito pequenas.

    recursos: limites: CPU: 1000m memória: 1024M solicitações: CPU: 1000m memória: 1024M

    vs

    recursos: limites: CPU: 1000m memória: 1024m solicitações: CPU: 1000m memória: 1024m

    capitalizar que m faz uma diferença muito grande no uso de recursos. Eu estava preso no ContainerCreating porque não havia dado memória suficiente ao meu contêiner.

    • 3
  5. Tej Arora
    2020-11-04T23:08:10+08:002020-11-04T23:08:10+08:00

    No meu caso, um pod ficou preso em ' ContainerCreating ' porque um pull de imagem do docker foi travado (algumas camadas foram baixadas, algumas ficaram presas em "download").

    $ kubectl get events --all-namespaces  --sort-by='.metadata.creationTimestamp'
    

    mostrou um evento "Puxando imagem"

    Tentei puxar essa imagem usando o docker image pull... e vi que estava travando.

    Descobriu-se que há um bug em pulls simultâneos de camadas. Alterar a configuração do docker para limitar a simultaneidade resolveu o problema.

    Adicionado isso à configuração do docker (no Windows, interface do usuário do docker-desktop, configurações, Docker Engine) para limitar a simultaneidade:

      "max-concurrent-downloads": 1,
      "max-concurrent-uploads": 1
    
    • 2

relate perguntas

  • Como posso saber quando/se/por que um contêiner em um cluster kubernetes é reiniciado?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve