add github deploy files

This commit is contained in:
vchikalkin 2025-06-27 18:27:03 +03:00
parent ed1fe77f62
commit 1d50c3168f
5 changed files with 128 additions and 1 deletions

10
.dockerignore Normal file
View File

@ -0,0 +1,10 @@
node_modules
build
tmp
.cache
.dockerignore
.git
.gitignore
.env
npm-debug.log
yarn-error.log

47
.github/workflows/deploy.yml vendored Normal file
View File

@ -0,0 +1,47 @@
name: Deploy Strapi
on:
push:
branches:
- main
jobs:
deploy:
environment: production
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Setup SSH key
run: |
mkdir -p ~/.ssh
echo "${{ secrets.VPS_SSH_KEY }}" > ~/.ssh/id_rsa
chmod 600 ~/.ssh/id_rsa
ssh-keyscan -H ${{ secrets.VPS_HOST }} >> ~/.ssh/known_hosts
- name: Sync project to VPS
run: |
rsync -avz --delete . ${{ secrets.VPS_USER }}@${{ secrets.VPS_HOST }}:/home/${{ secrets.VPS_USER }}/strapi-app
- name: Deploy on VPS
run: |
ssh ${{ secrets.VPS_USER }}@${{ secrets.VPS_HOST }} "
cd /home/${{ secrets.VPS_USER }}/strapi-app && \
docker network create app || true && \
export APP_KEYS='${{ secrets.APP_KEYS }}' && \
export API_TOKEN_SALT='${{ secrets.API_TOKEN_SALT }}' && \
export ADMIN_JWT_SECRET='${{ secrets.ADMIN_JWT_SECRET }}' && \
export TRANSFER_TOKEN_SALT='${{ secrets.TRANSFER_TOKEN_SALT }}' && \
export JWT_SECRET='${{ secrets.JWT_SECRET }}' && \
export DATABASE_CLIENT=postgres && \
export DATABASE_HOST='${{ secrets.POSTGRES_HOST }}' && \
export DATABASE_PORT=5432 && \
export DATABASE_NAME='${{ secrets.POSTGRES_DB }}' && \
export DATABASE_USERNAME='${{ secrets.POSTGRES_USER }}' && \
export DATABASE_PASSWORD='${{ secrets.POSTGRES_PASSWORD }}' && \
export DATABASE_SSL=false && \
docker-compose down && \
docker-compose up -d --build
"

41
Dockerfile Normal file
View File

@ -0,0 +1,41 @@
# -------------------
# 1. Build stage
# -------------------
FROM node:18-alpine AS builder
# Устанавливаем pnpm глобально
RUN npm install -g pnpm
WORKDIR /app
# Копируем манифесты и устанавливаем зависимости
COPY pnpm-lock.yaml ./
COPY package.json ./
RUN pnpm install --frozen-lockfile
# Копируем исходники и билдим Strapi admin
COPY . .
RUN pnpm build
# ------------------------
# 2. Runtime stage
# ------------------------
FROM node:18-alpine
# Устанавливаем pnpm
RUN npm install -g pnpm
WORKDIR /app
# Копируем только lockfile и package.json
COPY pnpm-lock.yaml ./
COPY package.json ./
RUN pnpm install --frozen-lockfile --prod
# Копируем билд и исходники из builder
COPY --from=builder /app .
# Открываем порт и запускаем
EXPOSE 1337
CMD ["pnpm", "start"]

View File

@ -1,7 +1,7 @@
import path from 'path';
export default ({ env }) => {
const client = env('DATABASE_CLIENT', 'sqlite');
const client = env('DATABASE_CLIENT', 'postgres');
const connections = {
mysql: {

29
docker-compose.yml Normal file
View File

@ -0,0 +1,29 @@
services:
strapi:
build: .
ports:
- "1337:1337"
environment:
# HOST: ${HOST}
# PORT: ${PORT}
APP_KEYS: ${APP_KEYS}
API_TOKEN_SALT: ${API_TOKEN_SALT}
ADMIN_JWT_SECRET: ${ADMIN_JWT_SECRET}
TRANSFER_TOKEN_SALT: ${TRANSFER_TOKEN_SALT}
# DATABASE_CLIENT: ${DATABASE_CLIENT}
DATABASE_HOST: ${DATABASE_HOST}
DATABASE_PORT: ${DATABASE_PORT}
DATABASE_NAME: ${DATABASE_NAME}
DATABASE_USERNAME: ${DATABASE_USERNAME}
DATABASE_PASSWORD: ${DATABASE_PASSWORD}
# DATABASE_SSL: ${DATABASE_SSL}
# DATABASE_FILENAME: ${DATABASE_FILENAME}
JWT_SECRET: ${JWT_SECRET}
networks:
- app
networks:
app:
external: true