Docker: 進階上下文使用

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

👋 歡迎來到 Stackhero 文件!

Stackhero 提供一個即用型的 Docker cloud 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 cloud hosting 解決方案,並將您的容器部署到生產環境!

使用 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 字符開頭,而不是空格。