From 0378a2b8c4e26dfcd8345901b266973d83f88734 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=82=B9=E6=96=B9=E6=88=90?= Date: Thu, 16 Oct 2025 14:35:45 +0800 Subject: [PATCH] =?UTF-8?q?ci(docker):=20=E6=B7=BB=E5=8A=A0=E6=9E=84?= =?UTF-8?q?=E5=BB=BAAPIDOC=E9=95=9C=E5=83=8F=E6=AD=A5=E9=AA=A4=E5=B9=B6?= =?UTF-8?q?=E6=9B=B4=E6=96=B0Makefile?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 在CI流程中添加构建APIDOC镜像的步骤,同时更新Makefile以支持相关操作 --- .gitea/workflows/docker.yaml | 12 +++- Makefile | 116 +++++++++++++++++++++++++++++++++++ 2 files changed, 127 insertions(+), 1 deletion(-) create mode 100644 Makefile diff --git a/.gitea/workflows/docker.yaml b/.gitea/workflows/docker.yaml index 469f0f3..97a85d9 100644 --- a/.gitea/workflows/docker.yaml +++ b/.gitea/workflows/docker.yaml @@ -83,8 +83,18 @@ jobs: - name: Build and push docker image run: | + source ${{gitea.WORKSPACE}}/deploy/.env go clean -modcache + go mod tidy make build-linux make docker make publish-docker - make docker-run \ No newline at end of file + make docker-run + + - name: Build APIDOC docker image + run: | + source ${{gitea.WORKSPACE}}/deploy/.env + echo ${SERVICE_NAME} + echo ${APIDOC_CONTAINER_NAME} + echo ${SWAGGER_JSON} + make swagger-docker \ No newline at end of file diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..50691e7 --- /dev/null +++ b/Makefile @@ -0,0 +1,116 @@ +# Custom configuration | 独立配置 +# Service name | 项目名称 +SERVICE=mini-chat +# Service name in specific style | 项目经过style格式化的名称 +SERVICE_STYLE=mini-chat +# Service name in lowercase | 项目名称全小写格式 +SERVICE_LOWER=mini-chat +# Service name in snake format | 项目名称下划线格式 +SERVICE_SNAKE=mini_chat +# Service name in snake format | 项目名称短杠格式 +SERVICE_DASH=mini-chat + +# The project version, if you don't use git, you should set it manually | 项目版本,如果不使用git请手动设置 +VERSION=$(shell git describe --tags --always) + +# The project file name style | 项目文件命名风格 +PROJECT_STYLE=go_zero + +# Whether to use i18n | 是否启用 i18n +PROJECT_I18N=true + +# The suffix after build or compile | 构建后缀 +PROJECT_BUILD_SUFFIX=api + +# Swagger type, support yml,json | Swagger 文件类型,支持yml,json +SWAGGER_TYPE=json + + +# ---- You may not need to modify the codes below | 下面的代码大概率不需要更改 ---- +GO ?= go +GOFMT ?= gofmt "-s" +GOFILES := $(shell find . -name "*.go") +LDFLAGS := -s -w + +.PHONY: test +test: # Run test for the project | 运行项目测试 + go test -v --cover ./internal/.. + +.PHONY: fmt +fmt: # Format the codes | 格式化代码 + $(GOFMT) -w $(GOFILES) + +.PHONY: lint +lint: # Run go linter | 运行代码错误分析 + golangci-lint run -D staticcheck + +.PHONY: tools +tools: # Install the necessary tools | 安装必要的工具 + $(GO) install github.com/golangci/golangci-lint/cmd/golangci-lint@latest; + $(GO) install github.com/go-swagger/go-swagger/cmd/swagger@latest + +.PHONY: docker +docker: # Build the docker image | 构建 docker 镜像 + docker build -f Dockerfile -t ${API_IMAGE_NAME}:${VERSION} . + @echo "Build docker successfully" + +.PHONY: publish-docker +publish-docker: # Publish docker image | 发布 docker 镜像 + echo "${DOCKER_PASSWORD}" | docker login --username ${DOCKER_USERNAME} --password-stdin ${REPO} + docker tag ${API_IMAGE_NAME}:${VERSION} ${API_IMAGE_NAME}:latest + docker push ${API_IMAGE_NAME}:latest + @echo "Publish docker successfully" + +.PHONY: docker-run +docker-run: # Publish docker image | 发布 docker 镜像 + docker rm -f ${API_CONTAINER_NAME} + docker compose -p ${DOCKER_PROJECT_NAME} -f ${DOCKER_COMPOSE_FILE} up -d + @echo "docker run successfully" + +.PHONY: swagger-docker +swagger-docker: # Run the swagger Docker | 运行接口文档服务 + @echo "run swagger-ui container..." + docker rm -f ${PROJECT_NAME}-${SERVICE_NAME}-apidoc + docker compose -p ${DOC_DOCKER_PROJECT_NAME} -f ${APIDOC_DOCKER_COMPOSE_FILE} up -d + @echo "run swagger-ui container successfully" + +.PHONY: gen-swagger +gen-swagger: # Generate swagger file | 生成 swagger 文件 + swagger generate spec --output=./$(SERVICE_STYLE).$(SWAGGER_TYPE) --scan-models + @echo "Generate swagger successfully" + +.PHONY: serve-swagger +serve-swagger: # Run the swagger server | 运行 swagger 服务 + lsof -i:36666 | awk 'NR!=1 {print $2}' | xargs killall -9 || true + swagger serve -F=swagger --port 36666 $(SERVICE_STYLE).$(SWAGGER_TYPE) + @echo "Serve swagger-ui successfully" + +.PHONY: gen-api +gen-api: # Generate API files | 生成 API 的代码 + goctls api go --api ./desc/all.api --dir ./ --trans_err=true --style=$(PROJECT_STYLE) + swagger generate spec --output=./$(SERVICE_STYLE).$(SWAGGER_TYPE) --scan-models + @echo "Generate API codes successfully" + +.PHONY: build-win +build-win: # Build project for Windows | 构建Windows下的可执行文件 + env CGO_ENABLED=0 GOOS=windows go build -ldflags "$(LDFLAGS)" -o $(SERVICE_STYLE)_$(PROJECT_BUILD_SUFFIX).exe $(SERVICE_STYLE).go + @echo "Build project for Windows successfully" + +.PHONY: build-mac +build-mac: # Build project for MacOS | 构建MacOS下的可执行文件 + env CGO_ENABLED=0 GOOS=darwin go build -ldflags "$(LDFLAGS)" -o $(SERVICE_STYLE)_$(PROJECT_BUILD_SUFFIX) $(SERVICE_STYLE).go + @echo "Build project for MacOS successfully" + +.PHONY: build-linux +build-linux: # Build project for Linux | 构建Linux下的可执行文件 + env CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags "$(LDFLAGS)" -o $(SERVICE_STYLE)_$(PROJECT_BUILD_SUFFIX) $(SERVICE_STYLE).go + @echo "Build project for Linux successfully" + +.PHONY: proto2api +proto2api: + goctls api proto --proto=/Users/mac/Desktop/backend/simple-admin/promotion/promotion-rpc/promotion.proto --style=go_zero --api_service_name=$(SERVICE) --rpc_service_name=$(SERVICE) --output=./ --model=$(model) --rpc_name=$(SERVICE) --grpc_package=promotion-rpc/types/$(SERVICE_LOWER) + @echo "generate api describe files successfully" + +.PHONY: help +help: # Show help | 显示帮助 + @grep -E '^[a-zA-Z0-9 -]+:.*#' Makefile | sort | while read -r l; do printf "\033[1;32m$$(echo $$l | cut -f 1 -d':')\033[00m:$$(echo $$l | cut -f 2- -d'#')\n"; done \ No newline at end of file