Compare commits
No commits in common. "8dc085c6a0263d9ce5d1dcc5128c03bd6d10f4ae" and "b46d0e50105b2aac4f71990a89f37cb544e27441" have entirely different histories.
8dc085c6a0
...
b46d0e5010
6 changed files with 53 additions and 121 deletions
|
|
@ -1,74 +1,45 @@
|
||||||
name: Build and Deploy Go App
|
name: Build and Deploy Go App
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
- cicd
|
|
||||||
|
jobs:
|
||||||
jobs:
|
build:
|
||||||
build:
|
runs-on: self-hosted
|
||||||
runs-on: ubuntu-latest
|
steps:
|
||||||
steps:
|
- name: Checkout code
|
||||||
- name: Checkout code
|
uses: actions/checkout@v4
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
- name: Build Go app
|
||||||
- uses: actions/setup-go@v6
|
run: |
|
||||||
with:
|
cd modules/server
|
||||||
go-version: '^1.25'
|
go mod tidy
|
||||||
check-latest: false
|
go build -o nyanimedb .
|
||||||
cache-dependency-path: |
|
|
||||||
modules/server/go.sum
|
- name: Build Docker image
|
||||||
|
run: |
|
||||||
- name: Set up Docker Buildx
|
cd modules/server
|
||||||
uses: docker/setup-buildx-action@v3
|
docker build -t nyanimedb:latest .
|
||||||
|
|
||||||
# Build application
|
deploy:
|
||||||
- name: Build Go app
|
runs-on: self-hosted
|
||||||
run: |
|
needs: build
|
||||||
cd modules/server
|
env:
|
||||||
go mod tidy
|
POSTGRES_USER: ${{ secrets.POSTGRES_USER }}
|
||||||
go build -o nyanimedb .
|
POSTGRES_PASSWORD: ${{ secrets.POSTGRES_PASSWORD }}
|
||||||
|
POSTGRES_DB: nyanimedb
|
||||||
- name: Upload built application to artifactory
|
POSTGRES_PORT: 5432
|
||||||
uses: actions/upload-artifact@v3
|
POSTGRES_VERSION: 18
|
||||||
with:
|
LOG_LEVEL: ${{ vars.LOG_LEVEL }}
|
||||||
name: nyanimedb
|
|
||||||
path: modules/server/nyanimedb
|
steps:
|
||||||
|
- name: Checkout code
|
||||||
# Build Docker image
|
uses: actions/checkout@v4
|
||||||
- name: Login to Docker Hub
|
|
||||||
uses: docker/login-action@v3
|
- name: Deploy containers locally
|
||||||
with:
|
run: |
|
||||||
registry: ${{ vars.REGISTRY }}
|
cd deploy
|
||||||
username: ${{ secrets.REGISTRY_USERNAME }}
|
docker compose down || true
|
||||||
password: ${{ secrets.REGISTRY_TOKEN }}
|
docker compose up -d
|
||||||
|
|
||||||
- name: Build and push
|
|
||||||
uses: docker/build-push-action@v6
|
|
||||||
with:
|
|
||||||
context: ./modules/server
|
|
||||||
file: Dockerfiles/Dockerfile_server
|
|
||||||
push: true
|
|
||||||
tags: meowgit.nekoea.red/nihonium/nyanimedb:latest
|
|
||||||
|
|
||||||
deploy:
|
|
||||||
runs-on: self-hosted
|
|
||||||
needs: build
|
|
||||||
env:
|
|
||||||
POSTGRES_USER: ${{ secrets.POSTGRES_USER }}
|
|
||||||
POSTGRES_PASSWORD: ${{ secrets.POSTGRES_PASSWORD }}
|
|
||||||
POSTGRES_DB: nyanimedb
|
|
||||||
POSTGRES_PORT: 5432
|
|
||||||
POSTGRES_VERSION: 18
|
|
||||||
LOG_LEVEL: ${{ vars.LOG_LEVEL }}
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Deploy containers locally
|
|
||||||
run: |
|
|
||||||
cd deploy
|
|
||||||
docker compose down || true
|
|
||||||
docker compose up -d
|
|
||||||
|
|
|
||||||
|
|
@ -1,24 +0,0 @@
|
||||||
FROM node:20-bookworm
|
|
||||||
|
|
||||||
ENV DEBIAN_FRONTEND=noninteractive
|
|
||||||
|
|
||||||
RUN apt-get update && \
|
|
||||||
apt-get install -y \
|
|
||||||
ca-certificates \
|
|
||||||
curl \
|
|
||||||
gnupg \
|
|
||||||
lsb-release \
|
|
||||||
sudo \
|
|
||||||
software-properties-common && \
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
RUN mkdir -p /etc/apt/keyrings && \
|
|
||||||
curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
|
|
||||||
|
|
||||||
RUN echo \
|
|
||||||
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian \
|
|
||||||
$(lsb_release -cs) stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null
|
|
||||||
|
|
||||||
RUN apt-get update && \
|
|
||||||
apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin && \
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
@ -1,20 +0,0 @@
|
||||||
FROM ubuntu:22.04
|
|
||||||
|
|
||||||
WORKDIR /app
|
|
||||||
COPY --chmod=755 nyanimedb /app
|
|
||||||
COPY templates /app/templates
|
|
||||||
EXPOSE 8080
|
|
||||||
ENTRYPOINT ["/app/nyanimedb"]
|
|
||||||
|
|
||||||
# FROM golang:1.25 AS builder
|
|
||||||
|
|
||||||
# ARG VERSION=dev
|
|
||||||
|
|
||||||
# WORKDIR /go/src/app
|
|
||||||
# COPY main.go .
|
|
||||||
# RUN go build -o main -ldflags=-X=main.version=${VERSION} main.go
|
|
||||||
|
|
||||||
# FROM debian:buster-slim
|
|
||||||
# COPY --from=builder /go/src/app/main /go/bin/main
|
|
||||||
# ENV PATH="/go/bin:${PATH}"
|
|
||||||
# CMD ["main"]
|
|
||||||
|
|
@ -1,2 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
docker buildx build --platform linux/amd64 -t meowgit.nekoea.red/nihonium/forgejo-runner:latest -f ./Dockerfiles/Dockerfile_forgejo-runner . --push
|
|
||||||
|
|
@ -27,7 +27,7 @@ services:
|
||||||
# - pgadmin_data:/var/lib/pgadmin
|
# - pgadmin_data:/var/lib/pgadmin
|
||||||
|
|
||||||
nyanimedb:
|
nyanimedb:
|
||||||
image: meowgit.nekoea.red/nihonium/nyanimedb:latest
|
image: nyanimedb:latest
|
||||||
container_name: nyanimedb
|
container_name: nyanimedb
|
||||||
restart: always
|
restart: always
|
||||||
environment:
|
environment:
|
||||||
|
|
|
||||||
7
modules/server/Dockerfile
Normal file
7
modules/server/Dockerfile
Normal file
|
|
@ -0,0 +1,7 @@
|
||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
COPY --chmod=755 nyanimedb /app
|
||||||
|
COPY templates /app/templates
|
||||||
|
EXPOSE 8080
|
||||||
|
ENTRYPOINT ["/app/nyanimedb"]
|
||||||
Loading…
Add table
Add a link
Reference in a new issue