1024개 이상의 도커 컨테이너 실행 중

1024개 이상의 도커 컨테이너 실행 중

브리지는 1023개의 MAC 주소로 제한되므로 일반 Docker는 1023개의 컨테이너로 제한됩니다.

하지만 다리가 여러 개 있다면 어떨까요? 그렇다면 1023개가 넘는 컨테이너를 가질 수 있나요?

라우터나 브리지를 통해 연결할 수 있나요?

그렇다면: 이를 수행하는 구성(바람직하게는 컨테이너를 외부 이더넷에서 사용할 수 있도록 만드는 구성)을 표시하십시오.

답변1

가능한. 이를 통해 6000개의 컨테이너를 성공적으로 실행했습니다.

    servers_min=$1
    servers_max=$2
    # We will start 10x this
    servers_min=$(( servers_min / 10 ))
    servers_max=$(( servers_max / 10 ))
    testssh() {
        ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/tmp/known root@"$1" echo "'$1'" '`uptime`'
    }
    export -f testssh
    docker network create --driver bridge net0
    docker network create --driver bridge net1
    docker network create --driver bridge net2
    docker network create --driver bridge net3
    docker network create --driver bridge net4
    docker network create --driver bridge net5
    docker network create --driver bridge net6
    docker network create --driver bridge net7
    docker network create --driver bridge net8
    docker network create --driver bridge net9
    # Start the virtual servers
    startone() {
        id=$1
        net=$2
        docker run -d --rm --name ubuntu-$id-$net --network $net my-ubuntu
        docker inspect ubuntu-$id-$net
    }
    export -f startone

    seq $servers_min $servers_max | parallel startone :::: - ::: net{0..9} |
        # After this it is possible to do:
        #   ssh 10.0.0.99
        # from another physical server
        perl -nE '/"IPAddress": "(\S+)"/ and not $seen{$1}++ and say $1' |
        tee /tmp/ipaddr |
        parallel testssh
    docker ps

서버는 동일한 브리지와 인터넷 내에서 서로 연결할 수 있지만 이더넷에서는 연결할 수 없습니다.

관련 정보