Docker: 高级上下文用法

如何在脚本中使用 Docker 上下文

👋 欢迎来到 Stackhero 文档!

Stackhero 提供现成的 Docker 云 CaaS (Containers as a Service) 解决方案,具有众多优势,包括:

  • 只需一个 docker-compose up,即可轻松将您的容器部署到生产环境
  • 使用 HTTPS 保护的可定制域名(例如,https://api.your-company.comhttps://www.your-company.comhttps://backoffice.your-company.com)。
  • 专用私有 VM提供的最佳性能强大安全性
  • 只需点击即可轻松更新

节省时间简化您的生活:只需 5 分钟即可尝试 Stackhero 的 Docker CaaS 云托管 解决方案,并将您的容器部署到生产环境!

使用 Docker context use 命令手动执行命令非常方便。但在使用脚本时,有更好的替代方法可以简化流程。您可以通过设置 DOCKER_CONTEXT 环境变量来设定所需的上下文,而不是直接调用命令。这种方法可以无缝集成到脚本工作流中,并保持配置的清晰性。

在提供的示例中,将 <XXXXXX>.stackhero-network.com 替换为您特定的 Docker 实例域名 (<XXXXXX>.stackhero-network.com)。

以下是如何在 bash 脚本中设置 Docker 上下文的示例:

#!/bin/bash
set -e

DOCKER_CONTEXT=<XXXXXX>.stackhero-network.com

echo "Stackhero 实例的 Docker IP:"
docker run --rm alpine wget -q -O - ifconfig.me

通过设置 DOCKER_CONTEXT 环境变量,您可以方便地在脚本中直接管理活动上下文。

为了避免硬编码 DOCKER_CONTEXT,您可以从 .env 文件加载其值。这种方法可以使环境设置井然有序,并便于调整:

#!/bin/bash
set -e

source .env

echo "Stackhero 实例的 Docker IP:"
docker run --rm alpine wget -q -O - ifconfig.me

创建一个包含以下内容的 .env 文件:

DOCKER_CONTEXT=<XXXXXX>.stackhero-network.com

您还可以在 Makefile 中设置 DOCKER_CONTEXT 变量。以下是导出变量并执行 Docker 容器的示例:

# Makefile
export DOCKER_CONTEXT=<XXXXXX>.stackhero-network.com

getIp:
	docker run --rm alpine wget -q -O - ifconfig.me

创建 Makefile 后,使用以下命令调用:

make getIp

如果遇到错误 Makefile: *** missing separator. Stop.,请确保 docker run [...] 行以 TAB 字符开头,而不是空格。

您可以通过在 Makefile 中包含 .env 文件来进一步简化配置。这种方法确保了环境设置的集中管理:

# Makefile
include .env
export

getIp:
	docker run --rm alpine wget -q -O - ifconfig.me

创建一个包含以下内容的 .env 文件:

DOCKER_CONTEXT=<XXXXXX>.stackhero-network.com

然后执行命令:

make getIp

如果遇到错误 Makefile: *** missing separator. Stop.,请验证 docker run [...] 行以 TAB 字符开头,而不是空格。