微信扫码
与创始人交个朋友
我要投稿
主要是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+中大型企业
2024-09-13
Dify v0.8.1:如何使用 OpenAI 的 o1 系列模型构建 LLM 应用?
2024-09-13
六大智能体平台大比拼:Coze如何脱颖而出?
2024-09-12
【AI Agent 教程】本地私有化部署Dify 的准备工作:
2024-09-10
Dify v0.8.0:Workflow 重磅更新 - 通过并行处理多个分支,显著提升速度
2024-09-09
Dify: 最强AI工作流应用开发平台指南
2024-09-05
关于如何理解dify中的异步和并发的概念
2024-09-03
手把手教你用Dify 工作流搭建资讯推送应用
2024-09-03
小红书运营一条龙 Dify 工作流 DSL 分享
2024-04-26
2024-04-25
2024-04-24
2024-05-08
2024-07-07
2024-05-07
2024-04-25
2024-05-08
2024-07-18
2024-07-20
2024-09-13
2024-09-13
2024-08-28
2024-08-06
2024-08-05
2024-07-20
2024-07-19
2024-07-18