
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本镜像基于 Ubuntu 操作系统定制,专为 LocalStack 设计,提供轻量、高效的本地 AWS 服务模拟环境。通过预配置 LocalStack 运行依赖及优化参数,简化本地开发、测试流程,帮助用户在离线环境中快速模拟 AWS 服务(如 S3、EC2、Lambda 等),无需连接真实 AWS 云环境。
awscli-local(本地 AWS CLI 客户端)、curl、jq 等,方便服务调试与资源管理。假设镜像名称为 localstack/ubuntu-custom(实际名称需替换为官方或私有仓库地址),通过以下命令拉取:
bashdocker pull localstack/ubuntu-custom:latest # 拉取最新版本 # 或指定 LocalStack 版本(如 3.0.0) docker pull localstack/ubuntu-custom:3.0.0
4.2.1 启动默认服务
运行镜像并启动 LocalStack 默认 AWS 服务(S3、Lambda、DynamoDB 等):
bashdocker run -d \ --name localstack-env \ -p 4566:4566 # LocalStack 统一 API 端口(所有服务入口) \ localstack/ubuntu-custom:latest
4.2.2 启动指定服务
通过 SERVICES 环境变量指定需启动的 AWS 服务(逗号分隔):
bashdocker run -d \ --name localstack-s3-ec2 \ -p 4566:4566 \ -e SERVICES=s3,ec2,lambda \ # 仅启动 S3、EC2、Lambda localstack/ubuntu-custom:latest
通过 -e 参数传递环境变量,自定义 LocalStack 行为。常用配置如下:
| 环境变量 | 说明 | 默认值 |
|---|---|---|
SERVICES | 需启动的 AWS 服务列表(逗号分隔),如 s3,lambda,dynamodb | s3,lambda,dynamodb,ec2 |
DEFAULT_REGION | 默认 AWS 区域,如 us-east-1、ap-southeast-1 | us-east-1 |
DATA_DIR | 本地数据持久化目录(容器内路径),用于保存服务状态(如 S3 存储数据) | /var/lib/localstack |
LOCALSTACK_API_KEY | LocalStack Pro 版本授权密钥(仅 Pro 版需要) | 空(社区版无需配置) |
DEBUG | 是否开启调试模式(输出详细日志),取值 1(开启)或 0(关闭) | 0 |
示例:启用调试模式并指定区域
bashdocker run -d \ --name localstack-dev \ -p 4566:4566 \ -e SERVICES=s3,dynamodb \ -e DEFAULT_REGION=ap-southeast-1 \ -e DEBUG=1 \ localstack/ubuntu-custom:latest
通过 Docker 卷(Volume)挂载本地目录至容器 DATA_DIR,实现服务状态持久化(如 S3 存储的文件、DynamoDB 表数据):
bashdocker run -d \ --name localstack-persist \ -p 4566:4566 \ -e DATA_DIR=/var/lib/localstack \ -v /本地目录/localstack-data:/var/lib/localstack \ # 本地目录替换为实际路径 localstack/ubuntu-custom:latest
如需覆盖 LocalStack 默认配置(如修改服务端口、调整资源限制),可通过挂载自定义配置文件实现:
localstack.conf 配置文件(参考 LocalStack 官方配置文档);bashdocker run -d \ --name localstack-custom-config \ -p 4566:4566 \ -v /本地路径/localstack.conf:/etc/localstack/localstack.conf \ # 挂载自定义配置 localstack/ubuntu-custom:latest
通过 docker-compose.yml 定义多服务环境(如 LocalStack + 应用服务),示例如下:
yamlversion: '3.8' services: localstack: image: localstack/ubuntu-custom:latest container_name: localstack ports: - "4566:4566" # 统一 API 端口 - "4510-4559:4510-4559" # 部分服务独立端口(可选) environment: - SERVICES=s3,lambda,dynamodb - DEFAULT_REGION=ap-southeast-1 - DATA_DIR=/var/lib/localstack - DEBUG=0 volumes: - ./localstack-data:/var/lib/localstack # 持久化数据 - /var/run/docker.sock:/var/run/docker.sock # 如需在容器内启动嵌套容器(如 Lambda 运行时)
启动命令:
bashdocker-compose up -d
通过 curl 或 awscli-local 检查服务是否正常运行:
bash# 检查 S3 服务可用性(创建测试桶) awslocal s3 mb s3://test-bucket # 查看 LocalStack 服务状态 curl http://localhost:4566/health | jq . # 需要安装 jq
bash# 停止容器 docker stop localstack-env # 重启容器(保留数据) docker restart localstack-env # 删除容器(需先停止) docker rm localstack-env
DATA_DIR 挂载本地卷,否则容器删除后数据丢失。-p 自定义端口:4566 映射至其他端口。LOCALSTACK_VERSION 固定版本(如 LOCALSTACK_VERSION=3.0.0)。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务