1
0
Fork 1
mirror of https://github.com/TeamOctolings/Octobot.git synced 2025-04-19 16:33:36 +03:00

Add Dockerfile and compose.yaml (#335)

This PR adds Dockerfile, to run Octobot within a Docker container, and
compose.yaml, to run the Octobot container along with any services that
the user may require.

---------

Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com>
Signed-off-by: mctaylors <cantsendmails@mctaylors.ru>
Co-authored-by: mctaylors <cantsendmails@mctaylors.ru>
This commit is contained in:
Octol1ttle 2024-10-27 20:40:27 +05:00 committed by GitHub
parent 9e44d49039
commit 8d74e5a96c
Signed by: GitHub
GPG key ID: B5690EEEBB952194
4 changed files with 61 additions and 11 deletions

View file

@ -8,22 +8,39 @@ on:
branches: [ "master" ] branches: [ "master" ]
jobs: jobs:
upload-solution: upload-container:
name: Upload Octobot to production name: Upload Octobot Docker container
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions: permissions:
actions: read packages: write
contents: read
environment: production environment: production
steps: steps:
- name: Checkout repository - name: Checkout repository
uses: actions/checkout@v4 uses: actions/checkout@v4
- name: Publish solution - name: Build container
run: dotnet publish $PUBLISH_FLAGS run: docker build --build-arg PUBLISH_OPTIONS=$PUBLISH_OPTIONS -t $IMAGE_NAME -f Dockerfile .
shell: bash
env: env:
PUBLISH_FLAGS: ${{vars.PUBLISH_FLAGS}} PUBLISH_OPTIONS: ${{vars.PUBLISH_OPTIONS}}
IMAGE_NAME: ${{vars.IMAGE_NAME}}
- name: Push container
run: |
echo $CR_PAT | docker login ghcr.io -u $REPO_OWNER --password-stdin
docker push ghcr.io/$NAMESPACE/$IMAGE_NAME:latest
shell: bash
env:
CR_PAT: ${{secrets.GITHUB_TOKEN}}
NAMESPACE: ${{vars.NAMESPACE}}
IMAGE_NAME: ${{vars.IMAGE_NAME}}
REPO_OWNER: ${{github.repository_owner}}
upload-solution:
name: Upload Octobot to production
runs-on: ubuntu-latest
environment: production
- name: Setup SSH key - name: Setup SSH key
run: | run: |
@ -44,15 +61,15 @@ jobs:
SSH_HOST: ${{secrets.SSH_HOST}} SSH_HOST: ${{secrets.SSH_HOST}}
STOP_COMMAND: ${{vars.STOP_COMMAND}} STOP_COMMAND: ${{vars.STOP_COMMAND}}
- name: Upload published solution - name: Update Docker image
run: | run: |
scp -r $UPLOAD_FROM $SSH_USER@$SSH_HOST:$UPLOAD_TO ssh $SSH_USER@$SSH_HOST docker pull ghcr.io/$NAMESPACE/$IMAGE_NAME:latest
shell: bash shell: bash
env: env:
SSH_USER: ${{secrets.SSH_USER}} SSH_USER: ${{secrets.SSH_USER}}
SSH_HOST: ${{secrets.SSH_HOST}} SSH_HOST: ${{secrets.SSH_HOST}}
UPLOAD_FROM: ${{vars.UPLOAD_FROM}} NAMESPACE: ${{vars.NAMESPACE}}
UPLOAD_TO: ${{vars.UPLOAD_TO}} IMAGE_NAME: ${{vars.IMAGE_NAME}}
- name: Start new instance - name: Start new instance
run: | run: |

1
.gitignore vendored
View file

@ -8,3 +8,4 @@ riderModule.iml
/.vs/ /.vs/
GuildData/ GuildData/
Logs/ Logs/
compose.yaml

15
Dockerfile Normal file
View file

@ -0,0 +1,15 @@
FROM mcr.microsoft.com/dotnet/sdk:8.0@sha256:35792ea4ad1db051981f62b313f1be3b46b1f45cadbaa3c288cd0d3056eefb83 AS build-env
WORKDIR /Octobot
# Copy everything
COPY . ./
# Load build argument with publish options
ARG PUBLISH_OPTIONS="-c Release"
# Build and publish a release
RUN dotnet publish ./TeamOctolings.Octobot $PUBLISH_OPTIONS -o out
# Build runtime image
FROM mcr.microsoft.com/dotnet/runtime:8.0@sha256:a335dccd3231f7f9e2122691b21c634f96e187d3840c8b7dbad61ee09500e408
WORKDIR /Octobot
COPY --from=build-env /Octobot/out .
ENTRYPOINT ["./TeamOctolings.Octobot"]

17
compose.example.yaml Normal file
View file

@ -0,0 +1,17 @@
services:
octobot:
container_name: octobot
build:
context: .
args:
- PUBLISH_OPTIONS
environment:
- BOT_TOKEN
volumes:
- guild-data:/Octobot/GuildData
- logs:/Octobot/Logs
restart: unless-stopped
volumes:
guild-data:
logs: