- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我尝试在 Travis-CI 上为多种架构构建一个 docker 镜像。这对 amd64 和 i386 工作得很好,但对 ARM 失败。
Dockerfile 构建在 {ARCH}/nextcloud:apache
之上,它构建在 php:7.3-apache-stretch
之上,再次使用 debian :拉伸(stretch) slim
。所以所有图像都使用相同的堆栈并且应该有相似的 react 。
.travis.yml
env:
- TAG=i386 ARCH=i386
- TAG=amd64 ARCH=amd64
- TAG=armhf ARCH=arm32v7
- TAG=aarch64 ARCH=arm64v8
before_script:
- docker run --rm --privileged multiarch/qemu-user-static:register --reset
script:
- docker build --pull --build-arg ARCH=$ARCH -t escoand/nextcloud:$TAG nextcloud
Dockerfile
ARG ARCH
FROM ${ARCH}/nextcloud:apache
RUN apt-get update && apt-get install -y supervisor && \
rm -rf /var/lib/apt/lists/* && \
mkdir /var/log/supervisord /var/run/supervisord
如前所述,i386 和 amd64 的构建没有问题。 ARM 构建已因第一个 RUN 命令而失败:
standard_init_linux.go:185: exec user process caused "no such file or directory"
The command '/bin/sh -c apt-get update && apt-get install -y supervisor && rm -rf /var/lib/apt/lists/* && mkdir /var/log/supervisord /var/run/supervisord' returned a non-zero code: 1
https://travis-ci.org/escoand/dockerfiles/jobs/562967055
对我来说,这听起来像 /bin/sh
是问题所在,但不知道如何处理。
最佳答案
首先,让我们了解一下,究竟您尝试使用以下技巧做什么:
before_script:
- docker run --rm --privileged multiarch/qemu-user-static:register --reset
当你要求 Linux 内核运行某个可执行文件时,它需要知道如何加载这个特定文件,以及这个文件是否与当前机器兼容。默认情况下,为 arm64v8
编译的 ELF 二进制文件被内核拒绝,在 amd64
硬件上运行。
然而,binfmt_misc内核的特性允许您告诉它如何处理它通常无法自行处理的可执行文件 - 这包括内核不知道二进制格式或认为它与当前机器不兼容的情况。
从图像 multiarch/qemu-user-static:register
开始的容器做了什么?它为为替代架构构建的 ELF 二进制文件注册新的处理程序,例如:
$ cat /proc/sys/fs/binfmt_misc/qemu-aarch64
enabled
interpreter /usr/bin/qemu-aarch64-static
flags:
offset 0
magic 7f454c460201010000000000000000000200b700
mask ffffffffffffff00fffffffffffffffffeffffff
当这个处理程序被注册时,内核知道它是否面对以魔术字节开头的二进制文件,在 magic
字段中指定(同时考虑到 mask
) ,它必须运行 /usr/bin/qemu-aarch64-static
二进制文件(解释器)并让它负责加载和运行请求的二进制文件。
您问题中的问题是:/usr/bin/qemu-aarch64-static
解释器在哪里,它知道如何在 上运行
? 没有,因为您使用的基础镜像不包含它(我手动提取并检查了 aarch64
二进制文件amd64arm64v8/nextcloud:apache
镜像以确认这一点)!
根据 execve(2)
的联机帮助页,当内核无法加载解释器时,它会返回“ENOENT”(没有这样的文件或目录)错误:
ERRORS
<...>
ENOENT The file pathname or a script or ELF interpreter does not exist,
or a shared library needed for the file or interpreter cannot be found.
所以,这就是发生的事情:您构建镜像并指定为 ARM 机器构建的基础镜像。在第一个 RUN
中,内核尝试从镜像执行 /bin/sh
文件,找到此类二进制文件的 QEMU 处理程序,然后寻找解释器,找不到它并失败,因此出现“没有这样的文件或目录”错误。
要解决这个问题,你必须使用安装了 QEMU 的基础镜像(因此,里面有 /usr/bin/qemu-aarch64-static
),这将允许你执行 RUN
s.
关于linux - ARM 镜像的 Docker 构建失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57178788/
我在使用以下代码时遇到问题: function http_file_exists($url){ $f=fopen($url,"r"); if($f){ fclose($f); retu
我已经通过 Git 部署到 Azure 几个月了,没有出现重大问题,但现在我似乎遇到了一个无法克服的错误。 我创建了一个新的 Azure 网站,为正在开发的项目创建单独的预览链接。我在新站点上设置了
我已经通过flutter创建了一个App并完成了它,我想在flutter文档中阅读时进行部署。 我收到此错误: FAILURE: Build failed with an exception. * W
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
我正在尝试使用 RapidJSON 解析从服务器接收到的数据。以下是收到的确切字符串: [ { "Node": "9478149a08f9", "Address": "172.17
我尝试为 ios 编译 OpenCV。我总是收到这些错误。我用不同版本的opencv试了一下,结果都是一样的。 我运行这个:python 平台/ios/build_framework.py ios_o
我在一台机器上做基本的发布/订阅,我的客户端是 StackExchange-Redis 的 C# 客户端,我在同一台机器上运行基于 Windows 的 Redis 服务器(服务器版本 2.8.4) 当
我有这段代码,但无法执行,请帮我解决这个问题 连接 connect_error) { die ("connection failed: " . $terhubung->connect_erro
我在 tomcat 上运行并由 maven 编译的 Web 应用程序给出了以下警告和错误。我可以在本地存储库中看到所有 JAR,但有人可以帮忙吗。 WARNING: Failed to scan JA
我正在 Windows 8 上使用 Android Studio 开发一个 android 应用程序,我正在使用一些 native 代码。突然间我无法编译我的 C 文件。当我运行 ndk-build
下面的代码对类和结构的成员进行序列化和反序列化。序列化工作正常,但我在尝试使用 oarch >> BOOST_SERIALIZATION_NVP(outObj); 反序列化时遇到了以下错误; 代码中是
如果我运行此命令“rspec ./spec/requests/api/v1/password_reset_request_spec.rb”,此文件中的所有测试都会通过。 但是,当我运行“rspec”时
我在尝试执行测试以使用 Protractor 上传文件时出错,我的代码是这个 it('it should be possible to upload a file', function() {
System.loadLibrary("nativefaceswap"); 当我运行我的应用程序时,我在 Android Studio 中发现了此类错误。在logcat中显示: java.lang.U
我希望有人能帮助我!使用任何方法或命令行的任何 SSL/HTTPS 调用均无效。 我在 Windows 10 中使用 Ubuntu Server 18.04 作为子系统。我的问题是昨天才开始出现的,因
通过删除这两个值将日期字段从 null=True 和 Blank=True 更改为 required 时,使用 db.alter 命令时遇到问题。 当以下行被注释掉时,迁移运行不会出现问题。
我第一次使用 Heroku 尝试创建应用程序(使用 SendGrid 的 Inbound Parse Webhook"和 Twilio SMS 通过电子邮件发送和接收 SMS 消息)。通过 Virtu
我正在将我的 swift 项目更新到 Xcode 7 上的 Swift 2.0。xcode 在构建项目时报告了以下错误: 命令/Applications/Xcode.app/Contents/Deve
在我的代码中,SSL 库函数 SSL_library_init() 没有按预期返回 1。我如何才能看到它返回了什么错误? 我在 SSL_library_init() 之后调用了 SSL_load_er
我正在尝试运行在以下链接中找到的答案: Asynchronously Load the Contents of a Div 但是当我这样做时,我会遇到我不太理解的错误。 我的代码: $(documen
我是一名优秀的程序员,十分优秀!