
trunk-bookworm-full, nightly-bookworm-fulltrunk-jammy-full, nightly-jammy-fulltrunk-full, nightly-fullbeta-bookworm-fullbeta-jammy-fullbeta-full3.2.2-bookworm-full3.2.2-bullseye-full3.2.2-buster-full, latest-buster-full3.2.2-noble-full3.2.2-jammy-full3.2.2-focal-full, latest-focal-full3.2.2-alpine-3.19-full3.2.2-alpine-3.19-slim3.2.2-alpine-3.19-minimal3.2.2-full, latest-full3.2.2-slim, latest-slim3.2.2-minimal, latest-minimal3.2.0-focal-full3.2.0-full3.2.0-slim3.2.0-minimal后续计划(需要帮助!)
Free Pascal是一款成熟、多功能的开源Pascal编译器。它支持多种处理器架构:Intel x86(16位和32位)、AMD64/x86-64、PowerPC、PowerPC64、SPARC、SPARC64、ARM、AArch64、MIPS、Motorola 68k、AVR和JVM。支持的操作系统包括Windows(16/32/64位、CE和原生NT)、Linux、Mac OS X/iOS/iPhoneSimulator/Darwin、FreeBSD和其他BSD变体、DOS(16位或32位DPMI)、OS/2、AIX、Android、Haiku、Nintendo GBA/DS/Wii、AmigaOS、MorphOS、AROS、Atari TOS以及各种嵌入式平台。此外,开发版本还支持RISC-V(32/64位)、Xtensa和Z80架构,以及LLVM编译器基础设施。
!alt text
使用此镜像最直接的方式是将容器同时作为构建和运行时环境。在Dockerfile中,以下内容将编译并运行项目:
dockerFROM freepascal/fpc:3.2.2-focal-full WORKDIR /usr/src/myapp COPY . . RUN fpc myapp.pas CMD ["myapp"]
然后,构建并运行Docker镜像:
console$ docker build -t my-fpc-app . $ docker run -it --rm --name my-running-app my-fpc-app
这将创建一个包含所有FPC工具的镜像。如果只需要编译后的应用:
dockerFROM freepascal/fpc:3.2.2-focal-full as builder WORKDIR /usr/src/myapp COPY . . RUN fpc myapp.pas FROM ubuntu:focal RUN apt-get update && apt-get upgrade && rm -rf /var/lib/apt/lists/* COPY --from=builder /usr/src/myapp/myapp /usr/local/bin/myapp CMD ["myapp"]
此方法将创建仅包含程序可执行文件的镜像。如果切换到基于Alpine的FPC镜像,可能可以节省空间。
有关更多信息,请参见多阶段构建。
有时可能不适合在容器内运行应用。要在Docker实例内编译而非运行应用,可以使用以下命令:
console$ docker run --rm --user "$(id -u)":"$(id -g)" -v "$PWD":/usr/src/myapp -w /usr/src/myapp freepascal/fpc:3.2.2-focal-full fpc -MDelphi myapp.lpr
这会将当前目录作为卷添加到容器,将工作目录设置为该卷,并运行命令fpc -MDelphi myapp.lpr。此命令指示FPC编译项目myapp以输出可执行文件。
FPC镜像有多种版本,每种版本设计用于特定场景。
https://hub.docker.com/_/debian%E6%98%AF%E4%B8%80%E7%A7%8DLinux%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F%EF%BC%8C%E6%98%AF%E4%B8%AA%E4%BA%BA%E8%AE%A1%E7%AE%97%E6%9C%BA%E5%92%8C%E7%BD%91%E7%BB%9C%E6%9C%8D%E5%8A%A1%E5%99%A8%E6%9C%80%E6%B5%81%E8%A1%8C%E7%9A%84Linux%E5%8F%91%E8%A1%8C%E7%89%88%E4%B9%8B%E4%B8%80%EF%BC%8C%E5%B7%B2%E8%A2%AB%E7%94%A8%E4%BD%9C%E5%85%B6%E4%BB%96%E5%A4%9A%E4%B8%AALinux%E5%8F%91%E8%A1%8C%E7%89%88%E7%9A%84%E5%9F%BA%E7%A1%80%E3%80%82
<version>-<debian>-full此镜像包含完整本地安装中的所有内容,包括文档和示例。
https://hub.docker.com/_/ubuntu%E6%98%AF%E5%9F%BA%E4%BA%8EDebian%E7%9A%84Linux%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F%EF%BC%8C%E5%8F%AF%E4%BB%8E%E6%A1%8C%E9%9D%A2%E8%BF%90%E8%A1%8C%E5%88%B0%E4%BA%91%E7%AB%AF%E3%80%82%E5%AE%83%E6%98%AF%E5%85%AC%E5%85%B1%E4%BA%91%E5%92%8COpenStack%E4%BA%91%E4%B8%AD%E6%9C%80%E5%8F%97%E6%AC%A2%E8%BF%8E%E7%9A%84%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F%EF%BC%8C%E4%B9%9F%E6%98%AF%E5%AE%B9%E5%99%A8%E7%9A%84%E9%A6%96%E9%80%89%E5%B9%B3%E5%8F%B0%EF%BC%9B%E4%BB%8EDocker%E5%88%B0Kubernetes%E5%86%8D%E5%88%B0LXD%EF%BC%8CUbuntu%E9%83%BD%E8%83%BD%E5%A4%A7%E8%A7%84%E6%A8%A1%E8%BF%90%E8%A1%8C%E5%AE%B9%E5%99%A8%E3%80%82%E5%BF%AB%E9%80%9F%E3%80%81%E5%AE%89%E5%85%A8%E4%B8%94%E7%AE%80%E5%8D%95%EF%BC%8CUbuntu%E4%B8%BA%E5%85%A8%E7%90%83%E6%95%B0%E7%99%BE%E4%B8%87%E5%8F%B0PC%E6%8F%90%E4%BE%9B%E6%94%AF%E6%8C%81%E3%80%82
<version>-<ubuntu>-full此镜像包含完整本地安装中的所有内容,包括文档和示例。
这些镜像基于流行的Alpine Linux项目,可在https://hub.docker.com/_/alpine%E4%B8%AD%E8%8E%B7%E5%8F%96%E3%80%82Alpine Linux比大多数发行版基础镜像小得多(约5MB),因此通常能生成更精简的镜像。
当最终镜像大小尽可能小是首要考虑因素时,此变体非常有用。主要注意事项是它使用musl libc而非glibc等,因此软件可能会根据其libc要求/假设的深度而遇到问题。有关可能出现的问题以及使用基于Alpine的镜像的优缺点比较,请参见此Hacker News评论线程。
为最小化镜像大小,基于Alpine的镜像通常不包含其他相关工具(如git或bash)。以此镜像为基础,可在自己的Dockerfile中添加所需工具(如果不熟悉如何安装包,请参见https://hub.docker.com/_/alpine/%E4%B8%AD%E7%9A%84%E7%A4%BA%E4%BE%8B%EF%BC%89%E3%80%82
<version>-full此镜像包含使用官方安装程序包正常安装FPC时的所有内容,但不包含示例和文档。
<version>-slim此镜像通过移除大多数包并仅保留核心包(完整RTL)和所有二进制文件,进一步减小了大小。
<version>-minimal此镜像包含所有二进制文件、最小RTL,可能仅用于编译新编译器和相应测试。
注意:镜像名称可能还包含Alpine Linux版本,格式为“<version>-alpine-<alpine_version>-(full|slim|minimal)”,表示它使用与Dockerfile中指定版本不同的Alpine版本。
这些镜像提供对FPC最新beta(修复)版本的便捷访问,即下一个稳定版本。它有Alpine Linux、Debian和Ubuntu版本,且预装了所有内容。
这些镜像提供对FPC最新开发(trunk)版本的便捷访问,该版本定期从FPC仓库的HEAD构建。它有Alpine Linux、Debian和Ubuntu版本,且预装了所有内容。
查看此镜像中包含软件的许可证信息。
与所有Docker镜像一样,这些镜像可能还包含其他软件,这些软件可能采用其他许可证(如基础发行版中的Bash等,以及主要包含软件的任何直接或间接依赖项)。
对于任何预构建镜像的使用,镜像用户有责任确保对该镜像的任何使用都符合其中包含的所有软件的相关许可证。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务