Dockerをプロキシサーバーがある環境で使う際に出たエラーの紹介です。
プロキシの設定
Dockerはイメージのダウンロードとかで色々とインターネット上のサーバーと通信するのでプロキシの設定が必要です。Dockerにプロキシ設定用の画面があるのでそこで適切にプロキシを設定します。
data:image/s3,"s3://crabby-images/48804/48804129345b532624f7c77ff08cb8e686e46957" alt=""
設定しないでイメージ(例はCentOS)を持って来ようとすると以下のようなエラーが発生します。
failed to solve with frontend dockerfile.v0: failed to create LLB definition: failed to do request: Head "https://registry-1.docker.io/v2/library/centos/manifests/7": dial tcp 52.20.81.6:443: connect: connection refused
Get "https://registry-1.docker.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers)
data:image/s3,"s3://crabby-images/100e3/100e3f708118f1dc7673ff951878930baefd5a29" alt=""
Buildkitの無効化
Dockerの設定画面でDocker Engineのタブを開き、buildkitをfalseにします。
data:image/s3,"s3://crabby-images/7d716/7d7163df0fb129d0dae762f2c01195cc135c54a4" alt=""
よく分かりませんがこれが無いと以下の様なエラーが発生します。バージョン18.09からデフォルトで有効になった機能でビルドが高速化されたりするそうですが残念ながら使えませんでした。
failed to solve with frontend dockerfile.v0: failed to create LLB definition: failed to authorize: rpc error: code = Unknown desc = failed to fetch anonymous token: Get "https://auth.docker.io/token?scope=repository%3Alibrary%2Fcentos%3Apull&service=registry.docker.io": dial tcp 3.224.96.239:443: connectex: No connection could be made because the target machine actively refused it.
data:image/s3,"s3://crabby-images/baf85/baf85ca1cd80d22b9ae21ed56bb1927a4e0136a3" alt=""