
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
该Docker镜像是专为ClojureScript开发设计的构建环境,集成了shadow-cljs工具链,旨在简化ClojureScript项目的编译、打包和开发流程。通过容器化方式,无需在本地配置JDK、Clojure或shadow-cljs依赖,即可快速搭建一致的ClojureScript构建环境。
开发模式(热重载)
启动开发模式并监听项目文件变化,修改后自动重新编译:
bashdocker run -it --rm \ -v $(pwd):/app \ # 挂载本地项目目录到容器/app路径 -w /app \ # 设置工作目录为/app -p 9630:9630 \ # 映射shadow-cljs仪表盘端口(可选) [镜像名称] \ # 替换为实际镜像名称 shadow-cljs watch app # "app"为项目中定义的构建目标(需在shadow-cljs.edn中配置)
执行后,通过http://localhost:9630可访问shadow-cljs仪表盘,查看构建状态和编译日志。
生产环境构建
执行优化编译,生成用于生产环境的代码(压缩、混淆、Tree-shaking):
bashdocker run -it --rm \ -v $(pwd):/app \ -w /app \ [镜像名称] \ shadow-cljs release app # "app"为构建目标
编译产物默认输出到项目的public/js目录(具体路径由shadow-cljs.edn配置定义)。
查看帮助信息
获取shadow-cljs命令列表和参数说明:
bashdocker run --rm [镜像名称] shadow-cljs help
为避免每次启动容器时重复下载依赖,可通过Docker卷持久化shadow-cljs缓存目录:
bash# 创建持久化卷(首次使用时执行) docker volume create shadow-cljs-cache # 使用卷启动容器 docker run -it --rm \ -v $(pwd):/app \ -v shadow-cljs-cache:/root/.shadow-cljs \ # 持久化缓存目录 -w /app \ [镜像名称] \ shadow-cljs watch app
| 环境变量名 | 说明 | 默认值 |
|---|---|---|
SHADOW_CLJS_VERSION | 指定shadow-cljs工具版本 | 镜像内置版本 |
JAVA_OPTS | Java运行时参数(如内存配置) | -Xmx512m(默认512MB堆内存) |
自定义Java内存配置示例
bashdocker run -it --rm \ -e JAVA_OPTS="-Xmx1g" \ # 调整Java堆内存为1GB -v $(pwd):/app \ -w /app \ [镜像名称] \ shadow-cljs release app
使用该镜像前,项目根目录需包含有效的shadow-cljs.edn配置文件,定义构建目标和编译选项。基础配置示例:
clojure{:source-paths ["src"] :dependencies [] :builds {:app {:target :browser :output-dir "public/js" :asset-path "/js" :modules {:main {:init-fn my.app/init}}}}}
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务