Docker "ERROR: ネットワークに割り当てるデフォルトの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
ここで tor
の Dockerfile
は次のようになっています。
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"]
ここで config
は次の2行で構成されています。
listen-address 0.0.0.0:8118
forward-socks5 / tor:9050 .
そして scraper
用の Dockerfile
は以下の通りである。
FROM python:2.7-alpine
ADD . /scraper
WORKDIR /scraper
RUN pip install -r requirements.txt
CMD ["python", "newnym.py"]
ここで requirements.txt
には requests
という一行が含まれている。最後に、newnym.py
は Tor を使って 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
このエラーメッセージに関するヘルプを検索してみましたが、見つかりませんでした。何がこのエラーを引き起こしているのでしょうか?
101
13
dockerが作成するネットワークの最大数に達しているのではないかという指摘を見たことがあります。コマンド
docker network prune
を使用すると、少なくとも1つのコンテナが使用していないネットワークをすべて削除できます。私の問題は結局、Robert がコメントしているように、openvpn の問題でした。
OpenVPNを実行していたので、この問題に遭遇しました。 OpenVPNを殺すとすぐに、「ドッカー構成」がすぐに起動し、エラーが消えました。
Peter Hauge]1'のコメントに従い、
docker network ls
を実行すると、(他の行の中に)以下のように表示された:NAME
と
DRIVERが両方とも
host`となっている行は、彼が言っている"ネットワークが既にホスト上に作成されている"ということのようです。そこで、https://gist.github.com/bastman/5b57ddb3c11942094f8d0a97d461b430、次のコマンドを実行した。これで
docker-compose up
は動作するようになりました(newnym.py
はエラーを出しますが)。私も同じ問題を抱えています。 私は「ドッカーシステムプルーン-a --volumes」、「ドッカーネットワークプルーン」を実行しましたが、どちらも私を助けませんでした。 私はVPNを使用し、VPNをオフにします。その後、ドッカーが正常に起動し、ネットワークを作成できます。 結局のところ、VPNを再度有効にすることができます。
私もOpenVPNの動作でこの問題に直面し、OpenVPNサーバーを停止/起動してはならないソリューションを見つけました。
使用したいサブネットを正確に指定する必要があるアイデア。
docker-compose.yml
で書く:それでおしまい。 これで、「デフォルト」ネットワークが使用され、VPNが
172.177.57から何かを割り当てなかった場合。*
サブネット元気です。他の回答で述べたように、Dockerのデフォルトのローカル「ブリッジ」ネットワークは30の異なるネットワークのみをサポートしています(それぞれ1つは名前で一意に識別可能です)。 それらを使用していない場合は、「ドッカーネットワークプルーン」でうまくいきます。
ただし、それぞれ独自のネットワークを備えた30を超えるコンテナを確立することに興味があるかもしれません。 そうすることに興味があったなら、「オーバーレイ」ネットワークを定義する必要があります。 これはもう少しトリッキーですが、非常によく文書化されていますここ。
同じエラーメッセージで同じ問題が発生したのですが、未使用の docker ネットワークを削除しても解決しませんでした。デフォルトでない docker ネットワークをすべて削除しましたが(イメージやコンテナもすべて)、それでも解決しませんでした。
問題の原因は、OpenVpn をインストールした後に残ったネットワークインターフェースにありました。(ifconfig`コマンドを実行して見つけました:
いくつかのコマンドで削除できることがわかりました:
この後、問題はなくなりました。
1。 他のコンテナが実行されているかどうかを確認します。実行されている場合は、「ドッカー構成ダウン」を実行します。 2。 VPNが接続されている場合は、VPNを切断して、ドッカーコンテナーをアップしてみてください。
試すことができます。
私のために働いた。
私は同じ問題を調査しました。その理由は、ネットワークの最大値に到達したためです。
する:
docker network ls
。docker network rm networkname_default
を使用して削除するものを選択します。「OpenVPN」を使用していたので、これが起こりました。 VPNの使用を中止したり、手動でネットワークをドッカー構成ファイルに追加したり、クレイジースクリプトを実行したりする必要がない方法を見つけました。
「OpenVPN」ではなく「WireGuard」に切り替えました。 より具体的には、nordvpnソリューションを実行しているときに、WireGuardをインストールし、そのバージョンであるNordLynxを使用しました。
TL; DR。
追加。
私はこの問題を段階的に修正しました。
1。 ネットワーク(ワイヤレスまたは有線)をオフにします。..)。
2。 システムを再起動します。
3。 PCでネットワークをオンにする前に、コマンドdocker-compose upを実行すると、新しいネットワークが作成されます。
4。 その後、ネットワークをオンにして続行できます。 ...