微信扫码
添加专属顾问
我要投稿
主要是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
定义伪目标,确保这些目标总是被执行,即使存在与目标同名的文件。
.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工程化(星球号)
53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费场景POC验证,效果验证后签署服务协议。零风险落地应用大模型,已交付160+中大型企业
2025-04-19
Dify工作流→变量系统的结构化总结
2025-04-18
扣子也可以一键转化为 MCP Server 了
2025-04-18
Dify 工作流中的loop节点:原理、用法与典型场景
2025-04-17
别再造轮子了!Dify+MCP+DeepSeek开发实战保姆级教程,打造AI应用72变
2025-04-16
Dify 技术内幕:插件系统设计与实现详解
2025-04-15
从开发角度对比 dify 和 n8n:哪个更适合你?
2025-04-14
把任意Dify工作流变成MCP Server
2025-04-14
Dify 升级攻略:从0.15.3迈向1.1.0,元数据管理全攻略!
2024-12-24
2024-04-25
2024-07-16
2024-07-20
2024-04-24
2024-06-21
2024-05-08
2024-05-09
2024-08-06
2024-11-15
2025-04-15
2025-03-20
2024-12-19
2024-09-13
2024-09-13
2024-08-28
2024-04-24