mirror of
https://github.com/versia-pub/server.git
synced 2025-12-06 08:28:19 +01:00
Add working Dockerfile
This commit is contained in:
parent
8b442c241c
commit
2c82cffb58
|
|
@ -13,3 +13,5 @@ helm-charts
|
||||||
.editorconfig
|
.editorconfig
|
||||||
.idea
|
.idea
|
||||||
coverage*
|
coverage*
|
||||||
|
uploads
|
||||||
|
logs
|
||||||
27
Dockerfile
27
Dockerfile
|
|
@ -1,8 +1,12 @@
|
||||||
# use the official Bun image
|
# use the official Bun image
|
||||||
# see all versions at https://hub.docker.com/r/oven/bun/tags
|
# see all versions at https://hub.docker.com/r/oven/bun/tags
|
||||||
FROM oven/bun:1.0.13-alpine as base
|
FROM oven/bun:1.0.14-alpine as base
|
||||||
WORKDIR /usr/src/app
|
WORKDIR /usr/src/app
|
||||||
|
|
||||||
|
RUN apk add vips-dev
|
||||||
|
# Required for Prisma to work
|
||||||
|
COPY --from=node:18-alpine /usr/local/bin/node /usr/local/bin/node
|
||||||
|
|
||||||
# install dependencies into temp directory
|
# install dependencies into temp directory
|
||||||
# this will cache them and speed up future builds
|
# this will cache them and speed up future builds
|
||||||
FROM base AS install
|
FROM base AS install
|
||||||
|
|
@ -13,13 +17,7 @@ RUN cd /temp/dev && bun install --frozen-lockfile
|
||||||
# install with --production (exclude devDependencies)
|
# install with --production (exclude devDependencies)
|
||||||
RUN mkdir -p /temp/prod
|
RUN mkdir -p /temp/prod
|
||||||
COPY package.json bun.lockb /temp/prod/
|
COPY package.json bun.lockb /temp/prod/
|
||||||
RUN cd /temp/prod && bun install --frozen-lockfile --production
|
RUN cd /temp/prod && bun install --frozen-lockfile --production.
|
||||||
|
|
||||||
# copy node_modules from temp directory
|
|
||||||
# then copy all (non-ignored) project files into the image
|
|
||||||
FROM install AS prerelease
|
|
||||||
COPY --from=install /temp/dev/node_modules node_modules
|
|
||||||
COPY . .
|
|
||||||
|
|
||||||
# copy production dependencies and source code into final image
|
# copy production dependencies and source code into final image
|
||||||
FROM base AS release
|
FROM base AS release
|
||||||
|
|
@ -27,9 +25,20 @@ FROM base AS release
|
||||||
# Create app directory
|
# Create app directory
|
||||||
RUN mkdir -p /app
|
RUN mkdir -p /app
|
||||||
COPY --from=install /temp/prod/node_modules /app/node_modules
|
COPY --from=install /temp/prod/node_modules /app/node_modules
|
||||||
COPY --from=prerelease /usr/src/app /app
|
COPY . /app
|
||||||
|
|
||||||
|
LABEL org.opencontainers.image.authors "Gaspard Wierzbinski (https://cpluspatch.dev)"
|
||||||
|
LABEL org.opencontainers.image.source "https://github.com/lysand-org/lysand"
|
||||||
|
LABEL org.opencontainers.image.vendor "Lysand Org"
|
||||||
|
LABEL org.opencontainers.image.licenses "AGPL-3.0"
|
||||||
|
LABEL org.opencontainers.image.title "Lysand Server"
|
||||||
|
LABEL org.opencontainers.image.description "Lysand Server docker image"
|
||||||
|
|
||||||
# run the app
|
# run the app
|
||||||
USER bun
|
USER bun
|
||||||
|
RUN bunx prisma generate
|
||||||
|
# Remove Node
|
||||||
|
USER root
|
||||||
|
RUN rm /usr/local/bin/node
|
||||||
|
USER bun
|
||||||
ENTRYPOINT [ "bun", "run", "index.ts" ]
|
ENTRYPOINT [ "bun", "run", "index.ts" ]
|
||||||
|
|
|
||||||
|
|
@ -9,7 +9,7 @@ database = "lysand"
|
||||||
host = "localhost"
|
host = "localhost"
|
||||||
post = 6379
|
post = 6379
|
||||||
password = ""
|
password = ""
|
||||||
database = 0
|
# database = 0
|
||||||
|
|
||||||
[http]
|
[http]
|
||||||
base_url = "https://lysand.social"
|
base_url = "https://lysand.social"
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,7 @@ const federationQueue = new Queue("federation", {
|
||||||
host: config.redis.queue.host,
|
host: config.redis.queue.host,
|
||||||
port: config.redis.queue.port,
|
port: config.redis.queue.port,
|
||||||
password: config.redis.queue.password,
|
password: config.redis.queue.password,
|
||||||
db: config.redis.queue.database,
|
db: config.redis.queue.database || undefined,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -114,7 +114,7 @@ export const federationWorker = new Worker(
|
||||||
host: config.redis.queue.host,
|
host: config.redis.queue.host,
|
||||||
port: config.redis.queue.port,
|
port: config.redis.queue.port,
|
||||||
password: config.redis.queue.password,
|
password: config.redis.queue.password,
|
||||||
db: config.redis.queue.database,
|
db: config.redis.queue.database || undefined,
|
||||||
},
|
},
|
||||||
removeOnComplete: {
|
removeOnComplete: {
|
||||||
count: 400,
|
count: 400,
|
||||||
|
|
|
||||||
|
|
@ -80,6 +80,7 @@
|
||||||
"jsonld": "^8.3.1",
|
"jsonld": "^8.3.1",
|
||||||
"marked": "^9.1.2",
|
"marked": "^9.1.2",
|
||||||
"prisma": "latest",
|
"prisma": "latest",
|
||||||
"sharp": "^0.32.6"
|
"semver": "^7.5.4",
|
||||||
|
"sharp": "^0.33.0-rc.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -14,7 +14,7 @@ export interface ConfigType {
|
||||||
host: string;
|
host: string;
|
||||||
port: number;
|
port: number;
|
||||||
password: string;
|
password: string;
|
||||||
database: number;
|
database: number | null;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -159,7 +159,7 @@ export const configDefaults: ConfigType = {
|
||||||
host: "localhost",
|
host: "localhost",
|
||||||
port: 6379,
|
port: 6379,
|
||||||
password: "",
|
password: "",
|
||||||
database: 0,
|
database: null,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
instance: {
|
instance: {
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue