微信扫码
与创始人交个朋友
我要投稿
主要是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-01-17
从 Dify 到 Rill-Flow:大模型应用平台的进化之路
2025-01-13
前后端源码部署:Dify v0.15.0 升级 v1.0.0-beta.1 的尝试
2025-01-11
Dify v1.0.0-beta:插件开启公测
2025-01-07
Dify v0.15.0:全新父子检索策略 - 更精准,更全面的知识检索
2024-12-27
【场景驱动】企业的哪些重复性任务,最适合用Coze循环节点来解决?——慢慢学AI146
2024-12-24
Coze,Dify,FastGPT,哪个更强?全方位对比分析来了!
2024-12-19
打开日本市场背后,Dify 是怎么做 AI 全球化的?
2024-12-15
有了 NewAPI 之后,Dify 的可玩儿性又高了
2024-04-25
2024-04-24
2024-07-16
2024-07-20
2024-05-08
2024-05-07
2024-05-09
2024-06-21
2024-12-24
2024-04-25