chore(build): add go-task support (#1608)

* chore(build): add go-task support

add go-task support

Signed-off-by: kovacs <mritd@linux.com>

* chore(docker): build with go-task

build with go-task

Signed-off-by: kovacs <mritd@linux.com>

* chore(task): support cross compile

support cross compile

Signed-off-by: kovacs <mritd@linux.com>

* chore(task): remove GCC build

remove GCC build

Signed-off-by: kovacs <mritd@linux.com>

* docs(task): update README

update README

Signed-off-by: kovacs <mritd@linux.com>

---------

Signed-off-by: kovacs <mritd@linux.com>
pull/1638/head
mritd 2 years ago committed by GitHub
parent 9c58278e08
commit abe90e4c88
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,49 +1,59 @@
# the frontend builder # the frontend builder
# cloudreve need node.js 16* to build frontend, # cloudreve need node.js 16* to build frontend,
# separate build step and custom image tag will resolve this # !!! Doesn't require any cleanup, as multi-stage builds are removed after completion
FROM node:16-alpine as cloudreve_frontend_builder FROM node:16-alpine as frontend_builder
RUN apk update \ RUN set -e \
&& apk add --no-cache wget curl git yarn zip bash \ && apk update \
&& git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git /cloudreve_frontend && apk add bash wget curl git zip \
&& sh -c "$(curl -sSL https://taskfile.dev/install.sh)" -- -d -b /usr/local/bin
# Maybe copying the current directory is more accurate?
# && git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git /cloudreve
# build frontend assets using build script, make sure all the steps just follow the regular release COPY . /cloudreve
WORKDIR /cloudreve_frontend
ENV GENERATE_SOURCEMAP false WORKDIR /cloudreve
RUN chmod +x ./build.sh && ./build.sh -a
RUN task clean-frontend build-frontend
# the backend builder # the backend builder
# cloudreve backend needs golang 1.18* to build # cloudreve backend needs golang 1.18* to build
FROM golang:1.18-alpine as cloudreve_backend_builder # !!! Doesn't require any cleanup, as multi-stage builds are removed after completion
FROM golang:1.18-alpine as backend_builder
# install dependencies and build tools # install dependencies and build tools
RUN apk update \ RUN set -e \
# install dependencies and build tools && apk update \
&& apk add --no-cache wget curl git build-base gcc abuild binutils binutils-doc gcc-doc zip bash \ && apk add bash wget curl git build-base \
&& git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git /cloudreve_backend && sh -c "$(curl -sSL https://taskfile.dev/install.sh)" -- -d -b /usr/local/bin
# Maybe copying the current directory is more accurate?
# && git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git /cloudreve
WORKDIR /cloudreve_backend COPY . /cloudreve
COPY --from=cloudreve_frontend_builder /cloudreve_frontend/assets.zip ./
RUN chmod +x ./build.sh && ./build.sh -c WORKDIR /cloudreve
COPY --from=frontend_builder /cloudreve/assets.zip ./
# TODO: merge the frontend build and backend build into a single one image RUN task clean-backend build-backend "PLATFORM=docker"
# the final published image
# the final builder
FROM alpine:latest FROM alpine:latest
WORKDIR /cloudreve WORKDIR /cloudreve
COPY --from=cloudreve_backend_builder /cloudreve_backend/cloudreve ./cloudreve
RUN apk update \ COPY --from=backend_builder /cloudreve/release/cloudreve-docker ./cloudreve
&& apk add --no-cache tzdata \
&& cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \ # !!! For i18n users, do not set timezone
&& echo "Asia/Shanghai" > /etc/timezone \ RUN set -e \
&& chmod +x ./cloudreve \ && apk update \
&& mkdir -p /data/aria2 \ && apk add bash ca-certificates tzdata \
&& chmod -R 766 /data/aria2 && rm -f /var/cache/apk/*
EXPOSE 5212 EXPOSE 5212
VOLUME ["/cloudreve/uploads", "/cloudreve/avatar", "/data"] VOLUME ["/cloudreve/uploads", "/cloudreve/avatar", "/data"]
ENTRYPOINT ["./cloudreve"] ENTRYPOINT ["./cloudreve"]

@ -74,50 +74,75 @@ The above is a minimum deploy example, you can refer to [Getting started](https:
## :gear: Build ## :gear: Build
You need to have `Go >= 1.18`, `node.js`, `yarn`, `zip` and other necessary dependencies before you can build it yourself. You need to have `Go >= 1.18`, `node.js`, `yarn`, `curl`, `zip`, `go-task` and other necessary dependencies before you can build it yourself.
#### Clone the code #### Install go-task
```shell ```shell
git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git sh -c "$(curl --location https://taskfile.dev/install.sh)" -- -d -b /usr/local/bin
``` ```
#### Build static resources For more installation methods, please refer to the official documentation: [https://taskfile.dev/installation/](https://taskfile.dev/installation/)
#### Clone the code
```shell ```shell
# Enter frontend sub-module git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git
cd assets
# Install dependencies
yarn install
# Start building
yarn run build
# Delete unused map files
cd build
find . -name "*.map" -type f -delete
# Return to main folder to pack static files
cd ../../
zip -r - assets/build >assets.zip
``` ```
#### Compile #### Compile
```shell ```shell
# Obtain version number, commit SHA # Enter the project directory
export COMMIT_SHA=$(git rev-parse --short HEAD) cd Cloudreve
export VERSION=$(git describe --tags)
# Execute the task command
# Note: The `task` command executes the task named `default` by default.
task
# Compile # View compiled files
go build -a -o cloudreve -ldflags "-s -w -X 'github.com/cloudreve/Cloudreve/v3/pkg/conf.BackendVersion=$VERSION' -X 'github.com/cloudreve/Cloudreve/v3/pkg/conf.LastCommit=$COMMIT_SHA'" ls release
``` ```
You can also start a quick build using `build.sh` in the project root directory: If you want to compile only the frontend code, please execute `task build-frontend`; similarly you can also execute `task build-backend` to only compile the backend code.
You can view all supported tasks through the `task --list` command:
```shell ```shell
./build.sh [-a] [-c] [-b] [-r] ~/Cloudreve task --list ✘ 146 master
a - Build assets task: Available tasks for this project:
c - Build binary backend * all: Build All Platform
b - Build both assets and backend * build: Build Cloudreve
r - Cross-compilation for final release * build-backend: Build Backend
* build-frontend: Build Frontend
* clean: Clean All Build Cache
* clean-backend: Clean Backend Build Cache
* clean-frontend: Clean Frontend Build Cache
* darwin-amd64: Build Backend(darwin-amd64)
* darwin-amd64-v2: Build Backend(darwin-amd64-v2)
* darwin-amd64-v3: Build Backend(darwin-amd64-v3)
* darwin-amd64-v4: Build Backend(darwin-amd64-v4)
* darwin-arm64: Build Backend(darwin-arm64)
* freebsd-386: Build Backend(freebsd-386)
* freebsd-amd64: Build Backend(freebsd-amd64)
* freebsd-amd64-v2: Build Backend(freebsd-amd64-v2)
* freebsd-amd64-v3: Build Backend(freebsd-amd64-v3)
* freebsd-amd64-v4: Build Backend(freebsd-amd64-v4)
* freebsd-arm: Build Backend(freebsd-arm)
* freebsd-arm64: Build Backend(freebsd-arm64)
* linux-amd64: Build Backend(linux-amd64)
* linux-amd64-v2: Build Backend(linux-amd64-v2)
* linux-amd64-v3: Build Backend(linux-amd64-v3)
* linux-amd64-v4: Build Backend(linux-amd64-v4)
* linux-armv5: Build Backend(linux-armv5)
* linux-armv6: Build Backend(linux-armv6)
* linux-armv7: Build Backend(linux-armv7)
* linux-armv8: Build Backend(linux-armv8)
* windows-amd64: Build Backend(windows-amd64)
* windows-amd64-v2: Build Backend(windows-amd64-v2)
* windows-amd64-v3: Build Backend(windows-amd64-v3)
* windows-amd64-v4: Build Backend(windows-amd64-v4)
* windows-arm64: Build Backend(windows-arm64)
``` ```
## :alembic: Stacks ## :alembic: Stacks

@ -74,50 +74,75 @@ chmod +x ./cloudreve
## :gear: 构建 ## :gear: 构建
自行构建前需要拥有 `Go >= 1.18`、`node.js`、`yarn`、`zip` 等必要依赖。 自行构建前需要拥有 `Go >= 1.18`、`node.js`、`yarn`、`curl`、`zip`、`go-task` 等必要依赖。
#### 克隆代码 #### 安装 go-task
```shell ```shell
git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git sh -c "$(curl --location https://taskfile.dev/install.sh)" -- -d -b /usr/local/bin
``` ```
#### 构建静态资源 对于其他平台或者其他安装方式, 请参考官方安装文档: [https://taskfile.dev/installation/](https://taskfile.dev/installation/)
#### 克隆代码
```shell ```shell
# 进入前端子模块 git clone --recurse-submodules https://github.com/cloudreve/Cloudreve.git
cd assets
# 安装依赖
yarn install
# 开始构建
yarn run build
# 构建完成后删除映射文件
cd build
find . -name "*.map" -type f -delete
# 返回项目主目录打包静态资源
cd ../../
zip -r - assets/build >assets.zip
``` ```
#### 编译项目 #### 编译项目
```shell ```shell
# 获得当前版本号、Commit # 进入项目目录
export COMMIT_SHA=$(git rev-parse --short HEAD) cd Cloudreve
export VERSION=$(git describe --tags)
# 执行 task 命令
# 提示: 单独执行 `task` 命令实际上默认执行叫做 `default` 的 task
task
# 开始编译 # 查看已编译好的文件
go build -a -o cloudreve -ldflags "-s -w -X 'github.com/cloudreve/Cloudreve/v3/pkg/conf.BackendVersion=$VERSION' -X 'github.com/cloudreve/Cloudreve/v3/pkg/conf.LastCommit=$COMMIT_SHA'" ls release
``` ```
你也可以使用项目根目录下的 `build.sh` 快速开始构建: 如果你期望单独编译前端代码, 请执行 `task build-frontend` 命令; 同样你可以通过执行 `task build-backend` 命令单独编译后端代码.
你可以通过执行 `task --list` 命令查看所以已支持的 task.
```shell ```shell
./build.sh [-a] [-c] [-b] [-r] ~/Cloudreve task --list ✘ 146 master ✱
a - 构建静态资源 task: Available tasks for this project:
c - 编译二进制文件 * all: Build All Platform
b - 构建前端 + 编译二进制文件 * build: Build Cloudreve
r - 交叉编译构建用于release的版本 * build-backend: Build Backend
* build-frontend: Build Frontend
* clean: Clean All Build Cache
* clean-backend: Clean Backend Build Cache
* clean-frontend: Clean Frontend Build Cache
* darwin-amd64: Build Backend(darwin-amd64)
* darwin-amd64-v2: Build Backend(darwin-amd64-v2)
* darwin-amd64-v3: Build Backend(darwin-amd64-v3)
* darwin-amd64-v4: Build Backend(darwin-amd64-v4)
* darwin-arm64: Build Backend(darwin-arm64)
* freebsd-386: Build Backend(freebsd-386)
* freebsd-amd64: Build Backend(freebsd-amd64)
* freebsd-amd64-v2: Build Backend(freebsd-amd64-v2)
* freebsd-amd64-v3: Build Backend(freebsd-amd64-v3)
* freebsd-amd64-v4: Build Backend(freebsd-amd64-v4)
* freebsd-arm: Build Backend(freebsd-arm)
* freebsd-arm64: Build Backend(freebsd-arm64)
* linux-amd64: Build Backend(linux-amd64)
* linux-amd64-v2: Build Backend(linux-amd64-v2)
* linux-amd64-v3: Build Backend(linux-amd64-v3)
* linux-amd64-v4: Build Backend(linux-amd64-v4)
* linux-armv5: Build Backend(linux-armv5)
* linux-armv6: Build Backend(linux-armv6)
* linux-armv7: Build Backend(linux-armv7)
* linux-armv8: Build Backend(linux-armv8)
* windows-amd64: Build Backend(windows-amd64)
* windows-amd64-v2: Build Backend(windows-amd64-v2)
* windows-amd64-v3: Build Backend(windows-amd64-v3)
* windows-amd64-v4: Build Backend(windows-amd64-v4)
* windows-arm64: Build Backend(windows-arm64)
``` ```
## :alembic: 技术栈 ## :alembic: 技术栈

@ -0,0 +1,414 @@
version: '3'
vars:
VERSION:
sh: git describe --tags --always
COMMIT_SHA:
sh: git rev-parse --short HEAD
CGO_ENABLED: 0
DEFAULT_PLATFORM: "{{OS}}-{{ARCH}}"
tasks:
clean-frontend:
desc: Clean Frontend Build Cache
cmds:
- rm -rf assets/build assets/node_modules assets.zip
status:
- test ! -d assets/build
- test ! -d assets/node_modules
- test ! -f assets.zip
clean-backend:
desc: Clean Backend Build Cache
cmds:
- rm -rf release
status:
- test ! -d release
clean:
desc: Clean All Build Cache
cmds:
- task: clean-frontend
- task: clean-backend
mkdir:
cmds:
- mkdir -p release
status:
- test -d release
build-frontend:
desc: Build Frontend
vars:
CI: false
GENERATE_SOURCEMAP: false
dir: assets
cmds:
- yarn install
- yarn build
- cd .. && zip -r - assets/build > assets.zip
status:
- test -d node_modules
- test -d build
build-backend:
desc: Build Backend
label: build-{{.PLATFORM | default "backend"}}
cmds:
- task: mkdir
- |
GOOS={{.GOOS}} GOARCH={{.GOARCH}} GOARM={{.GOARM}} GOMIPS={{.GOMIPS}} CGO_ENABLED={{.CGO_ENABLED}} CC={{.CC}} \
go build -trimpath -o release/cloudreve-{{.PLATFORM}}{{.BINEXT}} -ldflags \
"-w -s -X github.com/cloudreve/Cloudreve/v3/pkg/conf.BackendVersion={{.VERSION}} \
-X github.com/cloudreve/Cloudreve/v3/pkg/conf.LastCommit={{.COMMIT_SHA}}"
linux-amd64:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: amd64
}
linux-amd64-v2:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: amd64,
GOAMD64: v2
}
linux-amd64-v3:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: amd64,
GOAMD64: v3
}
linux-amd64-v4:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: amd64,
GOAMD64: v4
}
linux-armv5:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: arm,
GOARM: 5
}
linux-armv6:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: arm,
GOARM: 6
}
linux-armv7:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: arm,
GOARM: 7
}
linux-armv8:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: linux,
GOARCH: arm64
}
#
# !!! modernc.org/libc doesn't support mips architecture yet
#
# linux-mips-hardfloat:
# desc: Build Backend({{.TASK}})
# cmds:
# - task: build-backend
# vars: {
# PLATFORM: "{{.TASK}}",
# GOOS: linux,
# GOARCH: mips,
# GOMIPS: hardfloat
# }
# linux-mipsle-softfloat:
# desc: Build Backend({{.TASK}})
# cmds:
# - task: build-backend
# vars: {
# PLATFORM: "{{.TASK}}",
# GOOS: linux,
# GOARCH: mipsle,
# GOMIPS: softfloat
# }
# linux-mipsle-hardfloat:
# desc: Build Backend({{.TASK}})
# cmds:
# - task: build-backend
# vars: {
# PLATFORM: "{{.TASK}}",
# GOOS: linux,
# GOARCH: mipsle,
# GOMIPS: hardfloat
# }
# linux-mips64:
# desc: Build Backend({{.TASK}})
# cmds:
# - task: build-backend
# vars: {
# PLATFORM: "{{.TASK}}",
# GOOS: linux,
# GOARCH: mips64
# }
# linux-mips64le:
# desc: Build Backend({{.TASK}})
# cmds:
# - task: build-backend
# vars: {
# PLATFORM: "{{.TASK}}",
# GOOS: linux,
# GOARCH: mips64le
# }
darwin-amd64:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: darwin,
GOARCH: amd64
}
darwin-amd64-v2:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: darwin,
GOARCH: amd64,
GOAMD64: v2
}
darwin-amd64-v3:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: darwin,
GOARCH: amd64,
GOAMD64: v3
}
darwin-amd64-v4:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: darwin,
GOARCH: amd64,
GOAMD64: v4
}
darwin-arm64:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: darwin,
GOARCH: arm64
}
freebsd-386:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: freebsd,
GOARCH: 386
}
freebsd-amd64:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: freebsd,
GOARCH: amd64
}
freebsd-amd64-v2:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: freebsd,
GOARCH: amd64,
GOAMD64: v2
}
freebsd-amd64-v3:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: freebsd,
GOARCH: amd64,
GOAMD64: v3
}
freebsd-amd64-v4:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: freebsd,
GOARCH: amd64,
GOAMD64: v4
}
freebsd-arm:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: freebsd,
GOARCH: arm
}
freebsd-arm64:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
GOOS: freebsd,
GOARCH: arm64
}
#
# The sqlite library does not support the windows 386 architecture
# https://gitlab.com/cznic/sqlite/-/issues/86
#
# windows-386:
# cmds:
# - task: build-backend
# vars: {
# PLATFORM: "{{.TASK}}",
# BINEXT: ".exe",
# GOOS: windows,
# GOARCH: 386
# }
windows-amd64:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
BINEXT: ".exe",
GOOS: windows,
GOARCH: amd64
}
windows-amd64-v2:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
BINEXT: ".exe",
GOOS: windows,
GOARCH: amd64,
GOAMD64: v2
}
windows-amd64-v3:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
BINEXT: ".exe",
GOOS: windows,
GOARCH: amd64,
GOAMD64: v3
}
windows-amd64-v4:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
BINEXT: ".exe",
GOOS: windows,
GOARCH: amd64,
GOAMD64: v4
}
windows-arm64:
desc: Build Backend({{.TASK}})
cmds:
- task: build-backend
vars: {
PLATFORM: "{{.TASK}}",
BINEXT: ".exe",
GOOS: windows,
GOARCH: arm64
}
build:
desc: Build Cloudreve
cmds:
- task: clean
- task: build-frontend
- task: build-backend
vars: {
PLATFORM: "{{.DEFAULT_PLATFORM}}",
BINEXT: "{{exeExt}}"
}
default:
cmds:
- task: build
all:
desc: Build All Platform
cmds:
- task: clean
- task: build-frontend
- task: linux-amd64
- task: linux-amd64-v2
- task: linux-amd64-v3
- task: linux-amd64-v4
- task: linux-armv5
- task: linux-armv6
- task: linux-armv7
- task: linux-armv8
- task: darwin-amd64
- task: darwin-amd64-v2
- task: darwin-amd64-v3
- task: darwin-amd64-v4
- task: darwin-arm64
- task: windows-amd64
- task: windows-amd64-v2
- task: windows-amd64-v3
- task: windows-amd64-v4
- task: windows-arm64
Loading…
Cancel
Save