• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

231
Views
¿Cómo compruebo que un host docker está en modo enjambre?

Después de ejecutar esto;

 eval $(docker-machine env mymachine)

¿Cómo verifico si el demonio de la ventana acoplable en mymachine es un administrador de enjambres?

about 3 years ago · Santiago Trujillo
3 answers
Answer question

0

Para verificar la membresía general del enjambre, mi método preferido es usar la salida formateada de docker info . Los posibles valores de esto son actualmente inactivo, pendiente, activo, bloqueado y error :

 case "$(docker info --format '{{.Swarm.LocalNodeState}}')" in inactive) echo "Node is not in a swarm cluster";; pending) echo "Node is not in a swarm cluster";; active) echo "Node is in a swarm cluster";; locked) echo "Node is in a locked swarm cluster";; error) echo "Node is in an error state";; *) echo "Unknown state $(docker info --format '{{.Swarm.LocalNodeState}}')";; esac

Para verificar el estado del administrador, en lugar de solo un nodo en un clúster, el campo que desea es .Swarm.ControlAvailable :

 docker info --format '{{.Swarm.ControlAvailable}}'

Eso generará "verdadero" para los administradores y "falso" para cualquier nodo que sea un trabajador o no en un enjambre.

Para identificar los nodos trabajadores, puede unirse a dos:

 if [ "$(docker info --format '{{.Swarm.LocalNodeState}}')" = "active" \ -a "$(docker info --format '{{.Swarm.ControlAvailable}}')" = "false" ]; then echo "node is a worker" else echo "node is not a worker" fi
about 3 years ago · Santiago Trujillo Report

0

También puede usar la docker info para ver el resultado de la propiedad Swarm ( inactive o active ).

Por ejemplo:

 function isSwarmNode(){ if [ "$(docker info | grep Swarm | sed 's/Swarm: //g')" == "inactive" ]; then echo false; else echo true; fi }
about 3 years ago · Santiago Trujillo Report

0

No tengo un nodo de enjambre a mano en este momento, pero parece que podría simplemente ejecutar algo como docker node ls . Al apuntar a un demonio docker que no está en el nodo de enjambre, eso da como resultado:

 Error response from daemon: This node is not a swarm manager. Use "docker swarm init" or "docker swarm join" to connect this node to swarm and try again.

Y devuelve un código de salida distinto de cero

 $ echo $? 1

Así que la prueba sería algo como:

 if docker node ls > /dev/null 2>&1; then echo this is a swarm node else echo this is a standalone node fi
about 3 years ago · Santiago Trujillo Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error