1.Makefile文件
主要是web和api镜像打包。
# Variables
DOCKER_REGISTRY=langgenius
WEB_IMAGE=$(DOCKER_REGISTRY)/dify-web
API_IMAGE=$(DOCKER_REGISTRY)/dify-api
VERSION=latest
# Build Docker images
build-web:
@echo "Building web Docker image: $(WEB_IMAGE):$(VERSION)..."
docker build -t $(WEB_IMAGE):$(VERSION) ./web
@echo "Web Docker image built successfully: $(WEB_IMAGE):$(VERSION)"
build-api:
@echo "Building API Docker image: $(API_IMAGE):$(VERSION)..."
docker build -t $(API_IMAGE):$(VERSION) ./api
@echo "API Docker image built successfully: $(API_IMAGE):$(VERSION)"
# Push Docker images
push-web:
@echo "Pushing web Docker image: $(WEB_IMAGE):$(VERSION)..."
docker push $(WEB_IMAGE):$(VERSION)
@echo "Web Docker image pushed successfully: $(WEB_IMAGE):$(VERSION)"
push-api:
@echo "Pushing API Docker image: $(API_IMAGE):$(VERSION)..."
docker push $(API_IMAGE):$(VERSION)
@echo "API Docker image pushed successfully: $(API_IMAGE):$(VERSION)"
# Build all images
build-all: build-web build-api
# Push all images
push-all: push-web push-api
build-push-api: build-api push-api
build-push-web: build-web push-web
# Build and push all images
build-push-all: build-all push-all
@echo "All Docker images have been built and pushed."
# Phony targets
.PHONY: build-web build-api push-web push-api build-all push-all build-push-all
# Variables
DOCKER_REGISTRY=langgenius
WEB_IMAGE=$(DOCKER_REGISTRY)/dify-web
API_IMAGE=$(DOCKER_REGISTRY)/dify-api
VERSION=latest
定义了一些变量:
-
DOCKER_REGISTRY:Docker 注册表的名称,这里是langgenius。 -
WEB_IMAGE:Web 镜像的名称,基于DOCKER_REGISTRY。 -
API_IMAGE:API 镜像的名称,基于DOCKER_REGISTRY。 -
VERSION:镜像的版本,这里设置为latest。
# Build Docker images
build-web:
@echo "Building web Docker image: $(WEB_IMAGE):$(VERSION)..."
docker build -t $(WEB_IMAGE):$(VERSION) ./web
@echo "Web Docker image built successfully: $(WEB_IMAGE):$(VERSION)"
构建 Web Docker 镜像的目标:
-
打印构建 Web Docker 镜像的信息。
-
执行
docker build命令,将./web目录下的内容构建成 Docker 镜像,并打标签为$(WEB_IMAGE):$(VERSION)。 -
打印构建成功的信息。
build-api:
@echo "Building API Docker image: $(API_IMAGE):$(VERSION)..."
docker build -t $(API_IMAGE):$(VERSION) ./api
@echo "API Docker image built successfully: $(API_IMAGE):$(VERSION)"
构建 API Docker 镜像的目标:
-
打印构建 API Docker 镜像的信息。
-
执行
docker build命令,将./api目录下的内容构建成 Docker 镜像,并打标签为$(API_IMAGE):$(VERSION)。 -
打印构建成功的信息。
# Push Docker images
push-web:
@echo "Pushing web Docker image: $(WEB_IMAGE):$(VERSION)..."
docker push $(WEB_IMAGE):$(VERSION)
@echo "Web Docker image pushed successfully: $(WEB_IMAGE):$(VERSION)"
推送 Web Docker 镜像的目标:
-
打印推送 Web Docker 镜像的信息。
-
执行
docker push命令,将$(WEB_IMAGE):$(VERSION)镜像推送到注册表。 -
打印推送成功的信息。
push-api:
@echo "Pushing API Docker image: $(API_IMAGE):$(VERSION)..."
docker push $(API_IMAGE):$(VERSION)
@echo "API Docker image pushed successfully: $(API_IMAGE):$(VERSION)"
推送 API Docker 镜像的目标:
-
打印推送 API Docker 镜像的信息。
-
执行
docker push命令,将$(API_IMAGE):$(VERSION)镜像推送到注册表。 -
打印推送成功的信息。
# Build all images
build-all: build-web build-api
构建所有 Docker 镜像的目标,依赖于 build-web 和 build-api 目标。
# Push all images
push-all: push-web push-api
推送所有 Docker 镜像的目标,依赖于 push-web 和 push-api 目标。
build-push-api: build-api push-api
构建并推送 API Docker 镜像的目标,依赖于 build-api 和 push-api 目标。
build-push-web: build-web push-web
构建并推送 Web Docker 镜像的目标,依赖于 build-web 和 push-web 目标。
# Build and push all images
build-push-all: build-all push-all
@echo "All Docker images have been built and pushed."
构建并推送所有 Docker 镜像的目标,依赖于 build-all 和 push-all 目标。完成后打印所有镜像已构建和推送成功的信息。
# Phony targets
.PHONY: build-web build-api push-web push-api build-all push-all build-push-all
定义伪目标,确保这些目标总是被执行,即使存在与目标同名的文件。
2..PHONY语法
.PHONY 是 Makefile 中的一个特殊指令,用于指定一组“伪目标”(phony targets)。伪目标不是文件名,它们只是标签,用来执行一组命令。通过将这些目标声明为伪目标,可以确保它们总是被执行,而不管是否存在与目标同名的文件。详细解释如下:
.PHONY: build-web build-api push-web push-api build-all push-all build-push-all
各个伪目标的解释:
-
build-web:
-
目标:构建 Web Docker 镜像。
-
命令:构建位于
./web目录下的 Docker 镜像,并打上标签$(WEB_IMAGE):$(VERSION)。 -
build-api:
-
目标:构建 API Docker 镜像。
-
命令:构建位于
./api目录下的 Docker 镜像,并打上标签$(API_IMAGE):$(VERSION)。 -
push-web:
-
目标:推送 Web Docker 镜像到 Docker 注册表。
-
命令:将
$(WEB_IMAGE):$(VERSION)推送到 Docker 注册表。 -
push-api:
-
目标:推送 API Docker 镜像到 Docker 注册表。
-
命令:将
$(API_IMAGE):$(VERSION)推送到 Docker 注册表。 -
build-all:
-
目标:构建所有 Docker 镜像。
-
依赖关系:依赖于
build-web和build-api目标。 -
push-all:
-
目标:推送所有 Docker 镜像到 Docker 注册表。
-
依赖关系:依赖于
push-web和push-api目标。 -
build-push-all:
-
目标:构建并推送所有 Docker 镜像。
-
依赖关系:依赖于
build-all和push-all目标。 -
命令:构建和推送所有 Docker 镜像后,打印“所有 Docker 镜像已构建和推送成功”的信息。
NLP工程化(公众号)
NLP工程化(星球号)


