注意:这是haskell镜像的amd64架构构建的"每架构"仓库——更多信息,请参见镜像文档中的"除amd64之外的架构?"和***镜像FAQ中的"Git中的镜像源已更改,现在该怎么办?"。
维护者:
Docker社区
获取帮助:
Docker社区Slack、Server Fault、Unix & Linux或Stack Overflow
Dockerfile链接9.12.2-bookworm, 9.12-bookworm, 9-bookworm, bookworm, 9.12.2, 9.12, 9, latest
9.12.2-slim-bookworm, 9.12-slim-bookworm, 9-slim-bookworm, slim-bookworm, 9-slim, slim
9.10.2-bullseye, 9.10-bullseye, 9-bullseye, bullseye, 9.10.2, 9.10
9.10.2-slim-bullseye, 9.10-slim-bullseye, 9-slim-bullseye, slim-bullseye
9.8.4-bullseye, 9.8-bullseye, 9.8.4, 9.8
9.8.4-slim-bullseye, 9.8-slim-bullseye, 9.8.4-slim, 9.8-slim
9.6.7-bullseye, 9.6-bullseye, 9.6.7, 9.6
9.6.7-slim-bullseye, 9.6-slim-bullseye, 9.6.7-slim, 9.6-slim
提交issue的位置:
[***]
支持的架构:(更多信息)
amd64、arm64v8
镜像制品详情:
repo-info仓库的repos/haskell/目录(历史记录)
(镜像元数据、传输大小等)
镜像更新:
official-images仓库的library/haskell标签
official-images仓库的library/haskell文件(历史记录)
本描述的来源:
docs仓库的haskell/目录(历史记录)
Haskell是一种惰性、函数式、静态类型编程语言,具有高级类型系统特性,如高阶、高kind多态性、单子效应、广义代数数据类型(GADT)、灵活的类型类、关联类型族等。
Haskell的ghc是一款可移植的优化编译器,提供外部函数接口(FFI)、LLVM后端,以及对并发、显式/隐式并行ism、运行时分析等的复杂运行时支持。其他Haskell工具如criterion、quickcheck、hpc和haddock提供高级基准测试、基于属性的测试、代码覆盖率和文档生成功能。
大量生产级Haskell库可从Hackage以Cabal包的形式获取。传统的cabal工具或较新的stack工具(7.10.3及以上版本可用)可用于简化Cabal包的使用。
!logo
本镜像包含最小化的Haskell工具链(ghc和cabal-install)以及尽可能包含的stack工具([***]stack目前不支持ARM64,因此该处理器架构不包含stack。
ARM64支持是新增的,现阶段应视为实验性。自8.10.7、9.0.2和9.2.1版本起添加了ARM64支持。
注意:GHC开发团队不支持旧版本发布分支(如7.8.x)。只有最近的两个次要版本会接收更新或显示在本页面顶部的“支持的标签...”部分。
此外,我们旨在支持Debian的两个最新版本(stable和oldstable)作为变体,未指定时最新版本为默认。
注意:当前Debian的
stable版本是11 bullseye,但Haskell工具链尚未支持。在此之前,默认仍为Debian 10 buster。我们已停止支持Debian 9 stretch。
使用ghci启动交互式解释器会话:
console$ docker run -it --rm amd64/haskell:9 GHCi, version 9.0.1: [***] :? for help Prelude>
使用stack容器化应用程序:
dockerfileFROM amd64/haskell:8.10 RUN stack install --resolver lts-17.14 pandoc citeproc ENTRYPOINT ["pandoc"]
使用cabal容器化应用程序:
dockerfileFROM amd64/haskell:8.10 RUN cabal update && cabal install pandoc citeproc ENTRYPOINT ["pandoc"]
使用利用构建缓存的Dockerfile迭代开发Haskell应用程序:
dockerfileFROM amd64/haskell:8 WORKDIR /opt/example RUN cabal update # 仅添加.cabal文件以捕获依赖项 COPY ./example.cabal /opt/example/example.cabal # Docker会将此命令缓存为一层,使我们可以修改源代码而无需重新安装依赖项 #(除非.cabal文件更改!) RUN cabal build --only-dependencies -j4 # 添加并安装应用程序代码 COPY . /opt/example RUN cabal install CMD ["example"]
happy、alex等的注意事项某些同时作为构建依赖的包(如happy和alex)不再包含在本镜像中(自amd64/haskell:8.2.2和amd64/haskell:8.4.3起)。存在一个引导问题,即可能假设这些工具中的一个或多个可用。如果遇到关于Cabal包中未明确指出的依赖项缺失的错误,需要显式标记它们进行安装。
Stack工具主要设计为直接在主机上运行,提供许多高级功能,如GHC引导和Docker集成。在容器镜像上下文中,某些功能(stack docker)与Docker抽象冲突,应避免使用。
另一个常见的混淆场景是默认Stackage快照。Stackage快照是一组固定到特定版本的Haskell包,以与特定GHC版本兼容。当要求Stack解析依赖项时,它通过resolver值引用特定快照。虽然应在项目中显式指定resolver,但也可能使用自动生成的默认值。该默认值由请求时从上游Stackage服务器获取的值确定,并指向最新的“LTS”快照。如果快照引用的GHC版本与Docker镜像中提供的不同,可能会看到如下消息:
consoleStep 2/3 : RUN stack install pandoc ---> Running in e20466d52060 Writing implicit global project config file to: /root/.stack/global-project/stack.yaml Note: You can change the snapshot via the resolver field there. Using latest snapshot resolver: lts-11.11 Downloading lts-11.11 build plan ... Downloaded lts-11.11 build plan. Compiler version mismatched, found ghc-8.4.3 (x86_64), but expected minor version match with ghc-8.2.2 (x86_64) (based on resolver setting in /root/.stack/global-project/stack.yaml). To install the correct GHC into /root/.stack/programs/x86_64-linux/, try running "stack setup" or use the "--install-ghc" flag.
在这种情况下,amd64/haskell Docker镜像中的GHC版本领先于默认Stack解析器预期的GHC版本。如输出所示,推荐的方法是通过stack.yml显式设置解析器。
consoleStep 2/3 : RUN stack install --resolver ghc-8.4.3 pandoc ---> Running in 0bd7f1fcc8b2 Writing implicit global project config file to: /root/.stack/global-project/stack.yaml Note: You can change the snapshot via the resolver field there. Using resolver: ghc-8.4.3 specified on command line Updating package index Hackage (mirrored at [***] ... Selected mirror [***]
使用--install-ghc的替代方法在Docker镜像上下文中没有意义,因此(自amd64/haskell:8.2.2和amd64/haskell:8.4.3起)全局install-ghc标志已设置为false,以避免在容器中引导新GHC的默认行为。
amd64/haskell镜像有多种变体,每种设计用于特定用例。
amd64/haskell:<version>这是默认镜像。如果不确定需求,可能需要使用此镜像。它设计为既可作为临时容器(挂载源代码并启动容器以运行应用程序),也可作为构建其他镜像的基础。
某些标签可能包含bookworm或bullseye等名称,这些是Debian的版本代号,表示镜像所基于的发行版。如果镜像需要安装除自带包之外的其他包,可能需要显式指定这些代号,以减少Debian新版本发布时的中断。
amd64/haskell:<version>-slim此镜像不包含默认标签中的常见包,仅包含运行ghc、cabal-install和stack所需的最小包。此外,不包含分析支持,节省约700MB空间。
如果关注镜像大小,建议使用slim镜像。
本镜像根据MIT许可证(LICENSE)授权,包含根据BSD许可证授权的软件:Glasgow Haskell Compiler License、Stack License。
与所有Docker镜像一样,这些镜像可能还包含其他根据其他许可证授权的软件(如基础发行版中的Bash等,以及主要软件的任何直接或间接依赖项)。
一些能够自动检测的附加许可证信息可能位于repo-info仓库的haskell/目录中。
对于任何预构建镜像的使用,镜像用户有责任确保对本镜像的任何使用符合其中包含的所有软件的相关许可证。

来自真实用户的反馈,见证轩辕镜像的优质服务
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像加速服务
在 Docker Desktop 配置镜像加速
Docker Compose 项目配置加速
Kubernetes 集群配置 Containerd
在宝塔面板一键配置镜像加速
Synology 群晖 NAS 配置加速
飞牛 fnOS 系统配置镜像加速
极空间 NAS 系统配置加速服务
爱快 iKuai 路由系统配置加速
绿联 NAS 系统配置镜像加速
QNAP 威联通 NAS 配置加速
Podman 容器引擎配置加速
HPC 科学计算容器配置加速
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名加速
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429