Merge pull request #71 from alimy/pr-docker-compose

optimize #68 add docker --build-arg support
pull/72/head
Michael Li 3 years ago committed by GitHub
commit 09529f2daa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,11 +1,21 @@
# build frontend # build frontend
FROM node:18-alpine as frontend FROM node:18-alpine as frontend
ARG API_HOST
ARG USE_API_HOST=yes
ARG EMBED_UI=yes
ARG USE_DIST=no
WORKDIR /web WORKDIR /web
COPY web/ ./ COPY web/ ./
RUN echo 'VITE_HOST=""'>.env && yarn && yarn build RUN [ $EMBED_UI != yes ] || [ $USE_API_HOST != yes ] || echo "VITE_HOST='$API_HOST'">.env
RUN [ $EMBED_UI != yes ] || [ $USE_DIST != no ] || (yarn && yarn build)
RUN [ $EMBED_UI = yes ] || mkdir dist || echo ""
# build backend # build backend
FROM golang:1.18-alpine AS backend FROM golang:1.18-alpine AS backend
ARG API_HOST
ARG USE_API_HOST=yes
ARG EMBED_UI=yes
ARG USE_DIST=no
RUN apk --no-cache --no-progress add --virtual \ RUN apk --no-cache --no-progress add --virtual \
build-deps \ build-deps \
build-base \ build-base \
@ -15,9 +25,14 @@ WORKDIR /paopao-ce
COPY . . COPY . .
COPY --from=frontend /web/dist ./web/dist COPY --from=frontend /web/dist ./web/dist
ENV GOPROXY=https://goproxy.cn ENV GOPROXY=https://goproxy.cn
RUN make build TAGS='embed' RUN [ $EMBED_UI != yes ] || make build TAGS='embed'
RUN [ $EMBED_UI = yes ] || make build
FROM alpine:3.16 FROM alpine:3.16
ARG API_HOST
ARG USE_API_HOST=yes
ARG EMBED_UI=yes
ARG USE_DIST=no
ENV TZ=Asia/Shanghai ENV TZ=Asia/Shanghai
RUN apk update && apk add --no-cache ca-certificates && update-ca-certificates RUN apk update && apk add --no-cache ca-certificates && update-ca-certificates

@ -111,6 +111,24 @@ PaoPao主要由以下优秀的开源项目/工具构建
``` ```
提示: 如果需要内嵌web前端ui请先构建web前端(建议设置web/.env为VITE_HOST="")。 提示: 如果需要内嵌web前端ui请先构建web前端(建议设置web/.env为VITE_HOST="")。
5. docker构建
```sh
# 默认参数构建, 默认内嵌web ui并设置api host为空
%> docker build -t your/paopao-ce:tag .
# 内嵌web ui并且自定义API host参数
%> docker build -t your/paopao-ce:tag --build-arg API_HOST=http://paopao.info .
# 内嵌web ui并且使用本地web/.env中的API host
%> docker build -t your/paopao-ce:tag --build-arg USE_API_HOST=no .
# 内嵌web ui并且使用本地编译的web/dist构建
%> docker build -t your/paopao-ce:tag --build-arg USE_DIST=yes .
# 只编译api server
%> docker build -t your/paopao-ce:tag --build-arg EMBED_UI=no .
```
#### 前端 #### 前端
1. 进入前端目录 `web`,编辑 `.env` 文件中后端服务地址,下载依赖包 1. 进入前端目录 `web`,编辑 `.env` 文件中后端服务地址,下载依赖包
@ -129,6 +147,20 @@ PaoPao主要由以下优秀的开源项目/工具构建
build完成后可以在dist目录获取编译产出配置nginx指向至该目录即可 build完成后可以在dist目录获取编译产出配置nginx指向至该目录即可
3. 使用Docker构建
```sh
%> cd web
# 默认参数构建
%> docker build -t your/paopao-ce:web .
# 自定义API host 参数构建
%> docker build -t your/paopao-ce:web --build-arg API_HOST=http://paopao.info .
# 使用本地编译的dist构建
%> docker build -t your/paopao-ce:web --build-arg USE_DIST=yes .
```
#### 桌面端 #### 桌面端
1. 进入前端目录 `web`,编辑 `.env` 文件中后端服务地址,下载依赖包 1. 进入前端目录 `web`,编辑 `.env` 文件中后端服务地址,下载依赖包
@ -174,7 +206,7 @@ PaoPao主要由以下优秀的开源项目/工具构建
volumes: volumes:
- ./config.yaml:/app/paopao-ce/config.yaml - ./config.yaml:/app/paopao-ce/config.yaml
ports: ports:
- 127.0.0.1:8008:8008 - 8008:8008
networks: networks:
- paopao-network - paopao-network
.... ....

@ -1,9 +1,19 @@
FROM library/nginx # build frontend
FROM node:18-alpine as frontend
ARG API_HOST
ARG USE_DIST=no
WORKDIR /web
COPY . .
RUN [ empty$API_HOST = empty ] || echo "VITE_HOST=$API_HOST" >.env
RUN [ $USE_DIST != no ] || (yarn && yarn build)
FROM library/nginx
ARG API_HOST
ARG USE_DIST=no
USER root USER root
# copy static files # copy static files
COPY ./dist/ /usr/share/nginx/html/ COPY --from=frontend /web/dist/ /usr/share/nginx/html/
# HEALTHCHECK # HEALTHCHECK
HEALTHCHECK --interval=5s --timeout=3s --retries=3 CMD service nginx status | grep running || exit 1 HEALTHCHECK --interval=5s --timeout=3s --retries=3 CMD service nginx status | grep running || exit 1
Loading…
Cancel
Save