docker - docker-compose build 需要很长时间 构建时我可以启用详细/调试日志吗?
问题描述
它卡在“Building blahblah”上大约 18 分钟以上,有时甚至更长......
等待很长时间后,一切都建立起来并运行起来。
docker-compose --verbose build
没有给我太多信息。
Docker 引擎 - 社区引擎版本:19.03.8
docker-compose 版本 1.25.4,构建 8d51620a
root@someserver:/opt/containers/sites/somesite.nz# docker-compose --verbose build
compose.config.config.find: Using configuration files: ./docker-compose.yml
docker.utils.config.find_config_file: Trying paths: ['/root/.docker/config.json', '/root/.dockercfg']
docker.utils.config.find_config_file: No config file found
docker.utils.config.find_config_file: Trying paths: ['/root/.docker/config.json', '/root/.dockercfg']
docker.utils.config.find_config_file: No config file found
urllib3.connectionpool._make_request: http://localhost:None "GET /v1.25/version HTTP/1.1" 200 862
compose.cli.command.get_client: docker-compose version 1.25.4, build 8d51620a
docker-py version: 4.1.0
CPython version: 3.7.5
OpenSSL version: OpenSSL 1.1.0l 10 Sep 2019
compose.cli.command.get_client: Docker base_url: http+docker://localhost
compose.cli.command.get_client: Docker version: Platform={'Name': 'Docker Engine - Community'}, Components=[{'Name': 'Engine', 'Version': '19.03.8', 'Details': {'ApiVersion': '1.40', 'Arch': 'amd64', 'BuildTime': '2020-03-11T01:24:19.000000000+00:00', 'Experimental': 'false', 'GitCommit': 'afacb8b7f0', 'GoVersion': 'go1.12.17', 'KernelVersion': '4.15.0-108-generic', 'MinAPIVersion': '1.12', 'Os': 'linux'}}, {'Name': 'containerd', 'Version': '1.2.13', 'Details': {'GitCommit': '7ad184331fa3e55e52b890ea95e65ba581ae3429'}}, {'Name': 'runc', 'Version': '1.0.0-rc10', 'Details': {'GitCommit': 'dc9208a3303feef5b3839f4323d9beb36df0a9dd'}}, {'Name': 'docker-init', 'Version': '0.18.0', 'Details': {'GitCommit': 'fec3683'}}], Version=19.03.8, ApiVersion=1.40, MinAPIVersion=1.12, GitCommit=afacb8b7f0, GoVersion=go1.12.17, Os=linux, Arch=amd64, KernelVersion=4.15.0-108-generic, BuildTime=2020-03-11T01:24:19.000000000+00:00
compose.cli.verbose_proxy.proxy_callable: docker inspect_network <- ('someproject_internal')
urllib3.connectionpool._make_request: http://localhost:None "GET /v1.25/networks/someproject_internal HTTP/1.1" 404 68
compose.cli.verbose_proxy.proxy_callable: docker inspect_network <- ('web')
urllib3.connectionpool._make_request: http://localhost:None "GET /v1.25/networks/web HTTP/1.1" 200 None
compose.cli.verbose_proxy.proxy_callable: docker inspect_network -> {'Attachable': False,
'ConfigFrom': {'Network': ''},
'ConfigOnly': False,
'Containers': {'31db88fbbf7b3cc7da09559e024287424c4c689afdb0e924558583339233fec3': {'EndpointID': '798b82453ee5b309bccd5cb230e440bbbb79fe2b7746e668291cd88ca76b3c2f',
'IPv4Address': '172.19.0.3/16',
'IPv6Address': '',
'MacAddress': '02:42:ac:13:00:03',
'Name': 'someproject_someproject_1'},
'405639a07d229936eabfd6a766a6ce053ca5647e11f06dec3d15413d5c230b5e': {'EndpointID': '2aec703aeb0a86ce68ffae4a042fc405be9996aa19d5c288701702fc40d4e486',
'IPv4Address': '172.19.0.10/16',
...
compose.project.build: es-someproject uses an image, skipping
compose.service.build: Building someproject
compose.cli.verbose_proxy.proxy_callable: docker build <- (path='/opt/containers/sites/somesite.nz', tag='someproject_someproject', rm=True, forcerm=False, pull=False, nocache=False, dockerfile=None, cache_from=None, labels=None, buildargs={}, network_mode=None, target=None, shmsize=None, extra_hosts=None, container_limits={'memory': None}, gzip=False, isolation=None, platform=None)
解决方案
这就是为什么上下文太大或太深的原因。尝试创建一个空文件夹,将 docker-compose.yml 和 Dockerfile 移到那里,然后
docker-compose build
docker-compose up -d
当您的上下文有很多文件夹、符号链接和/或太深时,通常会出现问题。上下文是您的 Dockerfile 所在的位置:
version: '3.8'
services:
your-srv:
build:
context: .
dockerfile: Dockerfile
image ...
推荐阅读
- sql-server - 在 SQL Server 中通过多个参数进行分组并通过参数连接结果
- json - 如何使用 JOLT 转换将顶级对象移动到数组属性
- java - Java获取用户所在的桌面编号
- elasticsearch - kibana 6 脚本化字段日期范围
- android - 无法在 Kotlin 中使用 MediaPlayer 播放 .opus 文件
- scala - 如何检查对列表中是否有交集?
- css - 在 CSS 中选择类中的类型元素
- service - Kubernetes Dashboard 服务无法访问
- python - 搜索具有相同日期、时间(时间 +/-30 秒)和事件名称的重复行
- python - 如何将字典键与字符串匹配并放入新字典?