Adding docker images
This commit is contained in:
14
.dockerignore
Normal file
14
.dockerignore
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
.github
|
||||||
|
.next
|
||||||
|
node_modules
|
||||||
|
.dockerignore
|
||||||
|
.env
|
||||||
|
.env.example
|
||||||
|
.gitignore
|
||||||
|
.gitlab-ci.yml
|
||||||
|
.npmrc
|
||||||
|
components.json
|
||||||
|
dev-db.yml
|
||||||
|
docker-compose.yml
|
||||||
|
Dockerfile
|
||||||
|
dprint.json
|
||||||
14
.gitlab-ci.yml
Normal file
14
.gitlab-ci.yml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
build:
|
||||||
|
image: docker:cli
|
||||||
|
stage: build
|
||||||
|
services:
|
||||||
|
- docker:dind
|
||||||
|
variables:
|
||||||
|
DOCKER_IMAGE_NAME: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
|
||||||
|
before_script:
|
||||||
|
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
|
||||||
|
script:
|
||||||
|
- |
|
||||||
|
docker build -t "$DOCKER_IMAGE_NAME" .
|
||||||
|
docker tag "$DOCKER_IMAGE_NAME" "$CI_REGISTRY_IMAGE:main"
|
||||||
|
docker push "$CI_REGISTRY_IMAGE:main"
|
||||||
19
Dockerfile
Normal file
19
Dockerfile
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
FROM node:18-alpine AS base
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN apk add --no-cache libc6-compat
|
||||||
|
COPY package.json pnpm-lock.yaml ./
|
||||||
|
RUN npm install --global corepack@latest && corepack enable pnpm && pnpm i --frozen-lockfile
|
||||||
|
COPY . .
|
||||||
|
ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
|
# RUN pnpm run build
|
||||||
|
ENV NODE_ENV=production
|
||||||
|
|
||||||
|
RUN addgroup --system --gid 1001 nodejs && adduser --system --uid 1001 nextjs && chown -R nextjs:nodejs .
|
||||||
|
|
||||||
|
USER nextjs
|
||||||
|
EXPOSE 3000
|
||||||
|
ENV PORT=3000
|
||||||
|
ENV HOSTNAME="0.0.0.0"
|
||||||
|
|
||||||
|
CMD ["pnpm", "container:build"]
|
||||||
33
docker-compose.yml
Normal file
33
docker-compose.yml
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
---
|
||||||
|
services:
|
||||||
|
linker:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: Dockerfile
|
||||||
|
container_name: linker
|
||||||
|
restart: unless-stopped
|
||||||
|
ports:
|
||||||
|
- 3000:3000
|
||||||
|
environment:
|
||||||
|
- NEXT_PUBLIC_BASE_URL=${NEXT_PUBLIC_BASE_URL}
|
||||||
|
- PG_USER=${PG_USER}
|
||||||
|
- PG_PASSWORD=${PG_PASSWORD}
|
||||||
|
- PG_HOST=${PG_HOST}
|
||||||
|
- PG_PORT=${PG_PORT}
|
||||||
|
- PG_DATABASE=${PG_DATABASE}
|
||||||
|
- BETTER_AUTH_SECRET=${BETTER_AUTH_SECRET}
|
||||||
|
- BETTER_AUTH_URL=${BETTER_AUTH_URL}
|
||||||
|
- AUTHENTIK_CLIENT_ID=${AUTHENTIK_CLIENT_ID}
|
||||||
|
- AUTHENTIK_CLIENT_SECRET=${AUTHENTIK_CLIENT_SECRET}
|
||||||
|
- AUTHENTIK_DISCOVERY_URL=${AUTHENTIK_DISCOVERY_URL}
|
||||||
|
- GRAVATAR_API_KEY=${GRAVATAR_API_KEY}
|
||||||
|
depends_on:
|
||||||
|
- db
|
||||||
|
db:
|
||||||
|
image: postgres:16.4
|
||||||
|
container_name: linker-postgres
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
- POSTGRES_USER=${PG_USER}
|
||||||
|
- POSTGRES_PASSWORD=${PG_PASSWORD}
|
||||||
|
- POSTGRES_DB=${PG_DATABASE}
|
||||||
@@ -3,7 +3,8 @@
|
|||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"docker": "pnpm db:migrate && pnpm start",
|
"container": "pnpm db:migrate && pnpm start",
|
||||||
|
"container:build": "pnpm db:migrate && pnpm start",
|
||||||
"dev": "next dev --turbopack",
|
"dev": "next dev --turbopack",
|
||||||
"build": "next build",
|
"build": "next build",
|
||||||
"start": "next start",
|
"start": "next start",
|
||||||
|
|||||||
Reference in New Issue
Block a user