Docker1.12 Worker not able to join in cluster(Swarm: Pending)

后端 未结 6 1068
南旧
南旧 2021-01-13 23:56

Manager Version Docker version 1.12.0-rc5, build a3f2063,

Worker version Docker version 1.12.0-rc5, build a3f2063.

Created Swarm m

相关标签:
6条回答
  • 2021-01-14 00:22

    According to dockers website Here they stated the ports to enable. Run the following commands on both the Swam Manager and worker nodes

    sudo ufw enable
    sudo ufw allow 22/tcp
    sudo ufw allow 2376/tcp
    sudo ufw allow 2377/tcp
    sudo ufw allow 7946/tcp
    sudo ufw allow 7946/udp
    sudo ufw allow 4789/udp
    sudo ufw reload
    

    We just gave access to the neccessary port. After running these commands, all docker commands should be working now.

    0 讨论(0)
  • 2021-01-14 00:23

    Just expose port 2377 of manager, it will work.

    It clearly means node unable to connect manager, so timeout happening to conform same just do telnet manager-ip 2377 (don't try ping, won't work).

    And if you are facing the same error even though all firewalls are disabled in both nodes and manager, then try to create another manager exposing port 2377 as below:

    docker-machine create --driver amazonec2 --amazonec2-open-port 2377 manager1
    

    And now try to join nodes to new manager created now, but port you are using to join should be 2377 if you gonna use diff then expose that port in above command. Doing same worked for me as I suspect it's because others used other different servers but I'm using same server for both manager and nodes.

    0 讨论(0)
  • 2021-01-14 00:27

    I was having the same issue. I was running coreos vms in Azure. I found out that all my vms had the same private ip address and different public ip addresses. This usually happens when the vms are part of the same security group, however it was not the case this time. The issue was the my account had reached the max number of resources, so I deleted the resources such as ip addresses, nsg, networks etc and then re-provisioned new vms, they had different private ips and when ran the command everything was fine. My docker version is 1.12.6

    0 讨论(0)
  • 2021-01-14 00:29

    The thing is, I was trying to join with wrong "port" (As docker swarm init shown in output).

    1) Before "docker swarm init", the docker running on port "4243" only. I have checked with netstat -tulp | grep docker. So I advertised with that port!

    root@veeru:~# netstat -tulpn | grep docker
    tcp6       0      0 :::4243                 :::*                    LISTEN      8750/dockerd 
    
    root@veeru:~# docker swarm init --advertise-addr "172.25.30.2:4243"
    Swarm initialized: current node (exvwgj0pu4cd124ljnblt9xff) is now a manager.
    
    To add a worker to this swarm, run the following command:
        docker swarm join \
        --token SWMTKN-1-5j9mpo8hepue6g1sjdas33thr92w1o9hlef5auwqpbxs3glt39-6zomhgu204m9alq51f632nzas \
        172.25.30.2:4243
    
    To add a manager to this swarm, run the following command:
        docker swarm join \
        --token SWMTKN-1-5j9mpo8hepue6g1sjdas33thr92w1o9hlef5auwqpbxs3glt39-axhgqgo4jqw4hv38x578m44wh \
        172.25.30.2:4243
    

    2) After docker swarm init, the docker is running with 4 port including the port 2377(netstat -tupln | grep docker).

    root@veeru:~# netstat -tulp | grep docker
    tcp6       0      0 [::]:2377               [::]:*                  LISTEN      8750/dockerd    
    tcp6       0      0 [::]:7946               [::]:*                  LISTEN      8750/dockerd    
    tcp6       0      0 [::]:4243               [::]:*                  LISTEN      8750/dockerd    
    udp6       0      0 [::]:7946               [::]:*                              8750/dockerd
    

    In point 1, it is telling to run docker swarm join with port 4243 in worker. Previously I did run like that!.(It wont work!)

    Later I did docker swarm leave and joined with port 2377. Now I am able to join!

    docker swarm join --token SWMTKN-1-5j9mpo8hepue6g1sjdas33thr92w1o9hlef5auwqpbxs3glt39-6zomhgu204m9alq51f632nzas 172.25.30.2:2377
    
    0 讨论(0)
  • 2021-01-14 00:35

    I was facing similar issue, While in my case port was getting blocked due to firewall rule.

    0 讨论(0)
  • 2021-01-14 00:37

    For me it was a firewall issue too.

    1. I tried to ping to the manager node and was pinging back

    2. Checked if the ports are opening using telnet and was not able to connect and figured out it was the port issue.

    If you are running Centos than the port can be easily opened using the firewalld

    Check if the firewalld is running

    sudo firewall-cmd --state
    

    Opening the port you want

    sudo firewall-cmd --zone=public --add-port=2377/tcp
    

    Change the port as per your node ports it is trying to connect to.

    0 讨论(0)
提交回复
热议问题