mirror of
https://github.com/labring/FastGPT.git
synced 2025-12-26 21:22:48 +00:00
Some checks are pending
Document deploy / sync-images (push) Waiting to run
Document deploy / generate-timestamp (push) Blocked by required conditions
Document deploy / build-images (map[domain:https://fastgpt.cn suffix:cn]) (push) Blocked by required conditions
Document deploy / build-images (map[domain:https://fastgpt.io suffix:io]) (push) Blocked by required conditions
Document deploy / update-images (map[deployment:fastgpt-docs domain:https://fastgpt.cn kube_config:KUBE_CONFIG_CN suffix:cn]) (push) Blocked by required conditions
Document deploy / update-images (map[deployment:fastgpt-docs domain:https://fastgpt.io kube_config:KUBE_CONFIG_IO suffix:io]) (push) Blocked by required conditions
Build FastGPT images in Personal warehouse / get-vars (push) Waiting to run
Build FastGPT images in Personal warehouse / build-fastgpt-images (map[arch:amd64 runs-on:ubuntu-24.04]) (push) Blocked by required conditions
Build FastGPT images in Personal warehouse / build-fastgpt-images (map[arch:arm64 runs-on:ubuntu-24.04-arm]) (push) Blocked by required conditions
Build FastGPT images in Personal warehouse / release-fastgpt-images (push) Blocked by required conditions
* perf: faq * index * delete dataset * delete dataset * perf: delete dataset * init * fix: faq * doc * fix: share link auth (#6063) * standard plan add custom domain config (#6061) * standard plan add custom domain config * bill detail modal * perf: vector count api * feat: custom domain & wecom bot SaaS integration (#6047) * feat: custom Domain type define * feat: custom domain * feat: wecom custom domain * chore: i18n * chore: i18n; team auth * feat: wecom multi-model message support * chore: wecom edit modal * chore(doc): custom domain && wecom bot * fix: type * fix: type * fix: file detect * feat: fe * fix: img name * fix: test * compress img * rename * editor initial status * fix: chat url * perf: s3 upload by buffer * img * refresh * fix: custom domain selector (#6069) * empty tip * perf: s3 init * sort provider * fix: extend * perf: extract filename --------- Co-authored-by: Roy <whoeverimf5@gmail.com> Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
100 lines
3.2 KiB
Docker
100 lines
3.2 KiB
Docker
# --------- install dependence -----------
|
|
FROM node:20.14.0-alpine AS maindeps
|
|
WORKDIR /app
|
|
|
|
ARG proxy
|
|
|
|
RUN [ -z "$proxy" ] || sed -i 's/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g' /etc/apk/repositories
|
|
RUN apk add --no-cache libc6-compat && npm install -g pnpm@9.4.0
|
|
|
|
# copy packages and one project
|
|
COPY pnpm-lock.yaml pnpm-workspace.yaml .npmrc ./
|
|
COPY ./packages ./packages
|
|
COPY ./projects/app/package.json ./projects/app/package.json
|
|
|
|
RUN [ -f pnpm-lock.yaml ] || (echo "Lockfile not found." && exit 1)
|
|
|
|
# if proxy exists, set proxy
|
|
RUN if [ -z "$proxy" ]; then \
|
|
pnpm i; \
|
|
else \
|
|
pnpm i --registry=https://registry.npmmirror.com; \
|
|
fi
|
|
|
|
# --------- builder -----------
|
|
FROM node:20.14.0-alpine AS builder
|
|
WORKDIR /app
|
|
|
|
ARG proxy
|
|
ARG base_url
|
|
|
|
# copy common node_modules and one project node_modules
|
|
COPY package.json pnpm-workspace.yaml .npmrc tsconfig.json ./
|
|
COPY --from=maindeps /app/node_modules ./node_modules
|
|
COPY --from=maindeps /app/packages ./packages
|
|
COPY ./projects/app ./projects/app
|
|
COPY --from=maindeps /app/projects/app/node_modules ./projects/app/node_modules
|
|
|
|
RUN [ -z "$proxy" ] || sed -i 's/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g' /etc/apk/repositories
|
|
|
|
RUN apk add --no-cache libc6-compat && npm install -g pnpm@9.4.0
|
|
|
|
ENV NODE_OPTIONS="--max-old-space-size=4096"
|
|
ENV NEXT_PUBLIC_BASE_URL=$base_url
|
|
RUN pnpm --filter=app build
|
|
|
|
# --------- runner -----------
|
|
FROM node:20.14.0-alpine AS runner
|
|
WORKDIR /app
|
|
|
|
ARG proxy
|
|
ARG base_url
|
|
|
|
# create user and use it
|
|
RUN addgroup --system --gid 1001 nodejs
|
|
RUN adduser --system --uid 1001 nextjs
|
|
|
|
RUN [ -z "$proxy" ] || sed -i 's/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g' /etc/apk/repositories
|
|
RUN apk add --no-cache curl ca-certificates \
|
|
&& update-ca-certificates
|
|
|
|
# copy running files
|
|
COPY --from=builder /app/projects/app/public /app/projects/app/public
|
|
COPY --from=builder /app/projects/app/next.config.js /app/projects/app/next.config.js
|
|
COPY --from=builder --chown=nextjs:nodejs /app/projects/app/.next/standalone /app/
|
|
COPY --from=builder --chown=nextjs:nodejs /app/projects/app/.next/static /app/projects/app/.next/static
|
|
# copy server chunks
|
|
COPY --from=builder --chown=nextjs:nodejs /app/projects/app/.next/server/chunks /app/projects/app/.next/server/chunks
|
|
# copy worker
|
|
COPY --from=builder --chown=nextjs:nodejs /app/projects/app/worker /app/projects/app/worker
|
|
|
|
# copy standload packages
|
|
COPY --from=maindeps /app/node_modules/tiktoken ./node_modules/tiktoken
|
|
RUN rm -rf ./node_modules/tiktoken/encoders
|
|
COPY --from=maindeps /app/node_modules/@zilliz/milvus2-sdk-node ./node_modules/@zilliz/milvus2-sdk-node
|
|
# copy package.json to version file
|
|
COPY --from=builder /app/projects/app/package.json ./package.json
|
|
# copy config
|
|
COPY ./projects/app/data/config.json /app/data/config.json
|
|
# copy test.mp3
|
|
COPY ./projects/app/data/test.mp3 /app/data/test.mp3
|
|
# copy GeoLite2-City.mmdb
|
|
COPY ./projects/app/data/GeoLite2-City.mmdb /app/data/GeoLite2-City.mmdb
|
|
|
|
RUN chown -R nextjs:nodejs /app/data
|
|
|
|
# Add tmp directory permission control
|
|
|
|
ENV NODE_ENV=production
|
|
ENV NEXT_TELEMETRY_DISABLED=1
|
|
ENV PORT=3000
|
|
ENV NEXT_PUBLIC_BASE_URL=$base_url
|
|
|
|
EXPOSE 3000
|
|
|
|
USER nextjs
|
|
|
|
ENV serverPath=./projects/app/server.js
|
|
|
|
ENTRYPOINT ["sh","-c","node --max-old-space-size=4096 ${serverPath}"]
|