
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
dockerdocker build -t pdok/mapserver . docker run -e MS_MAPFILE=/srv/data/example.map --rm -d \ -p 80:80 --name mapserver-example -v `pwd`/example:/srv/data pdok/mapserver docker stop mapserver-example
本项目旨在满足两个需求:
为满足第一个需求,主要目的是创建可在Kubernetes等平台上运行的Docker基础镜像。
关于第二个需求,找到可用的https://github.com/mapserver/mapserver Docker镜像是一个挑战。大多数镜像在GetCapabilities中暴露&map=...查询字符串,不运行在FastCGI模式下,且基于Apache。
本项目将创建一个通过Lighttpd运行的Mapserver应用。通过lua脚本过滤传入请求中的map=...查询字符串,即只能通过环境变量设置使用的Mapfile。
包含的EPSG文件(包含投影参数)仅包含少量可用的EPSG代码,即本组织使用的那些。如果需要使用其他EPSG投影,可以覆盖此文件。
Docker镜像包含两个阶段:
builder阶段编译Mapserver。Dockerfile中明确列出了所有可用的Mapserver构建选项,清晰显示哪些选项已启用和禁用。
service阶段将第一阶段构建的Mapserver应用复制到该阶段,并配置Lighttpd。
dockerdocker build -t pdok/mapserver .
对于特定的荷兰版本,包含特定(更小的)epsg文件和必要的网格校正文件:
dockerdocker build -t pdok/mapserver:nl -f Dockerfile.NL .
此镜像可直接从命令行运行。需要将卷挂载到容器目录/srv/data,挂载的卷需包含与MS_MAPFILE环境变量匹配的*.map文件。
shdocker run \ --rm -d \ -e MS_MAPFILE=/srv/data/example.map \ -p 80:80 \ --name mapserver-example \ -v `pwd`/example:/srv/data \ pdok/mapserver
运行上述示例将在http://localhost/?REQUEST=GetCapabilities&SERVICE=WMS创建服务,可接受类似GetMap请求。
可设置的环境变量如下:
DEBUG:调试模式开关MIN_PROCS:最小进程数MAX_PROCS:最大进程数MAX_LOAD_PER_PROC:每个进程的最大负载IDLE_TIMEOUT:空闲超时时间MS_MAPFILE:Mapfile路径(必需)PROJ_LIB:PROJ投影文件目录除MS_MAPFILE外,其他环境变量在Dockerfile中有默认值。
GDAL的PROJ_LIB环境变量默认值为/usr/share/proj。为提高性能,可设置包含最少可用EPSG代码的自定义PROJ_LIB,通过上述PROJ_LIB环境变量实现。
shdocker run \ --rm -d \ -p 80:80 \ --name mapserver-run-example \ -v `pwd`/example:/srv/data \ -e DEBUG=0 \ -e MIN_PROCS=1 \ -e MAX_PROCS=3 \ -e MAX_LOAD_PER_PROC=4 \ -e IDLE_TIMEOUT=20 \ -e MS_MAPFILE=/srv/data/example.map \ pdok/mapserver
修改proj文件的原因包括添加自定义投影或删除“未使用”的投影以提高性能。可通过以下几种方式实现:
最佳示例是本仓库中的Dockerfile.NL。该Dockerfile以主Dockerfile为基础镜像,复制特定的大地测量网格文件,并使用为荷兰优化的epsg文件覆盖默认文件。
大地测量文件的良好资源是PROJ.org Datumgrid CDN。
另一种方式是创建proj文件(如nl文件夹中的文件),将其挂载到容器,并通过以下参数设置PROJ_LIB环境变量指向该位置:
sh-e PROJ_LIB=/my-custom-proj-dir \ -v `pwd`/path/to/proj/dir:/my-custom-proj-dir \
启动容器后,将在访问点http://localhost创建WMS和WFS服务。
http://localhost/?SERVICE=WFS&REQUEST=GetCapabilitieshttp://localhost/?SERVICE=WMS&REQUEST=GetCapabilitieshttp://localhost/?SERVICE=WFS&VERSION=2.0.0&REQUEST=GetFeature&TYPENAMES=example:example&COUNT=1http://localhost/?SERVICE=WMS&VERSION=1.3.0&REQUEST=GetMap&BBOX=50,2,54,9&CRS=EPSG:4326&WIDTH=905&HEIGHT=517&LAYERS=example&STYLES=&FORMAT=image/png&DPI=96&MAP_RESOLUTION=96&FORMAT_OPTIONS=dpi:96&TRANSPARENT=TRUEhttp://localhost/?SERVICE=WMS&VERSION=1.3.0&REQUEST=GetFeatureInfo&BBOX=48.9306039592783506,0.48758765231731171,55.46504193821721884,12.33319204541738756&CRS=EPSG:4326&WIDTH=1530&HEIGHT=844&LAYERS=example&STYLES=&FORMAT=image/png&QUERY_LAYERS=example&INFO_FORMAT=text/html&I=389&J=537&FEATURE_COUNT=10在之前的配置中,我们使用NGINX,虽然它是一个优秀的Web服务且有很多配置选项,但它运行多个进程,因此需要supervisord进行管理,而lighttpd作为单个进程运行。此外,路由配置选项不是必需的,因为这由基础设施/平台(如Kubernetes)处理。如果需要配置简单路由,仍可在lighttpd.conf中完成。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务