Docker「エラー: ネットワークに割り当てるデフォルトの中で、重複しない利用可能な IPv4 アドレス プールが見つかりませんでした」質問する

Docker「エラー: ネットワークに割り当てるデフォルトの中で、重複しない利用可能な IPv4 アドレス プールが見つかりませんでした」質問する

apkmirror-scraper-compose次のような構造のディレクトリがあります。

.
├── docker-compose.yml
├── privoxy
│   ├── config
│   └── Dockerfile
├── scraper
│   ├── Dockerfile
│   ├── newnym.py
│   └── requirements.txt
└── tor
    └── Dockerfile

以下を実行しようとしていますdocker-compose.yml:

version: '3'

services:
  privoxy:
    build: ./privoxy
    ports:
      - "8118:8118"
    links:
      - tor

  tor:
    build:
      context: ./tor
      args:
        password: ""
    ports:
      - "9050:9050"
      - "9051:9051"

  scraper:
    build: ./scraper
    links:
      - tor
      - privoxy

ここDockerfiletor

FROM alpine:latest
EXPOSE 9050 9051
ARG password
RUN apk --update add tor
RUN echo "ControlPort 9051" >> /etc/tor/torrc
RUN echo "HashedControlPassword $(tor --quiet --hash-password $password)" >> /etc/tor/torrc
CMD ["tor"]

それprivoxy

FROM alpine:latest
EXPOSE 8118
RUN apk --update add privoxy
COPY config /etc/privoxy/config
CMD ["privoxy", "--no-daemon"]

config2つの線で構成される

listen-address 0.0.0.0:8118
forward-socks5 / tor:9050 .

そしてDockerfileforscraper

FROM python:2.7-alpine
ADD . /scraper
WORKDIR /scraper
RUN pip install -r requirements.txt
CMD ["python", "newnym.py"]

にはrequirements.txt1 行が含まれますrequests。最後に、このプログラムはnewnym.pyTor を使用して IP アドレスを変更することが機能するかどうかを単純にテストするように設計されています。

from time import sleep, time

import requests as req
import telnetlib


def get_ip():
    IPECHO_ENDPOINT = 'http://ipecho.net/plain'
    HTTP_PROXY = 'http://privoxy:8118'
    return req.get(IPECHO_ENDPOINT, proxies={'http': HTTP_PROXY}).text


def request_ip_change():
    tn = telnetlib.Telnet('tor', 9051)
    tn.read_until("Escape character is '^]'.", 2)
    tn.write('AUTHENTICATE ""\r\n')
    tn.read_until("250 OK", 2)
    tn.write("signal NEWNYM\r\n")
    tn.read_until("250 OK", 2)
    tn.write("quit\r\n")
    tn.close()


if __name__ == '__main__':
    dts = []
    try:
        while True:
            ip = get_ip()
            t0 = time()
            request_ip_change()
            while True:
                new_ip = get_ip()
                if new_ip == ip:
                    sleep(1)
                else:
                    break
            dt = time() - t0
            dts.append(dt)
            print("{} -> {} in ~{}s".format(ip, new_ip, int(dt)))
    except KeyboardInterrupt:
        print("Stopping...")
        print("Average: {}".format(sum(dts) / len(dts)))

ビルドdocker-compose buildは正常に完了しましたが、実行しようとするとdocker-compose up次のエラー メッセージが表示されます。

Creating network "apkmirrorscrapercompose_default" with the default driver
ERROR: could not find an available, non-overlapping IPv4 address pool among the defaults to assign to the network

このエラー メッセージに関するヘルプを検索してみましたが、見つかりませんでした。このエラーの原因は何ですか?

ベストアンサー1

docker が作成したネットワークの数が最大に達している可能性があるという表示を見ました。このコマンドをdocker network prune使用すると、少なくとも 1 つのコンテナで使用されていないすべてのネットワークを削除できます。

私の問題は結局、ロバートコメント: openvpn の問題により、service openvpn stop問題が「解決」されました。

おすすめ記事