Compare commits

...

11 Commits

Author SHA1 Message Date
Dustin Pianalto
940781cb83 Add pgbouncer
Some checks are pending
CI / build (push) Waiting to run
2021-10-10 21:54:49 -08:00
Dustin Pianalto
3a7bf68ba9 Update registry
Some checks are pending
CI / build (push) Waiting to run
2021-10-05 23:47:59 -08:00
Dustin Pianalto
243fa19e36 Don't run migrations
Some checks are pending
CI / build (push) Waiting to run
2021-10-02 17:56:03 -08:00
Dustin Pianalto
fcbf803ae2 Merge branch 'development'
Some checks are pending
CI / build (push) Waiting to run
2021-10-02 17:17:28 -08:00
Dustin Pianalto
47ecefb048 Update action
Some checks are pending
CI / build (push) Waiting to run
2021-10-02 16:59:49 -08:00
Dustin Pianalto
7bffb96431 Update deployment and action
Some checks are pending
CI / build (push) Waiting to run
2021-10-02 16:58:26 -08:00
Dustin Pianalto
14390c5c21 Update deployment and action
Some checks are pending
CI / build (push) Waiting to run
2021-10-02 16:42:40 -08:00
Dustin Pianalto
1e88425853 force bot to run on node with label
Some checks are pending
CI / build (push) Waiting to run
2021-07-19 13:06:16 -08:00
Dustin Pianalto
eacdd455f9 force bot to run on node with label
Some checks are pending
CI / build (push) Waiting to run
2021-07-19 12:49:57 -08:00
Dustin Pianalto
1e184c97a2 Test broadcast response
Some checks are pending
CI / build (push) Waiting to run
2021-06-30 22:00:38 -08:00
Dustin Pianalto
8c2bb50637 Test broadcast response
Some checks are pending
CI / build (push) Waiting to run
2021-06-30 21:54:35 -08:00
4 changed files with 69 additions and 29 deletions

View File

@ -20,41 +20,45 @@ jobs:
- name: Get Version - name: Get Version
id: get_version id: get_version
uses: battila7/get-version-action@v2.0.0 uses: battila7/get-version-action@v2.0.0
- name: Install go-bindata and build migrations - name: install buildx
env: id: buildx
GOPATH: /home/runner/work/Geeksbot/ uses: crazy-max/ghaction-docker-buildx@v1
run: |
go get -u github.com/go-bindata/go-bindata/...
/home/runner/work/Geeksbot/bin/go-bindata -pkg migrations -prefix $GITHUB_WORKSPACE/pkg/database/migrations/ -o $GITHUB_WORKSPACE/pkg/database/migrations/bindata.go $GITHUB_WORKSPACE/pkg/database/migrations/
head $GITHUB_WORKSPACE/pkg/database/migrations/bindata.go
- name: Build container image
env:
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
run: docker build -t registry.digitalocean.com/djpianalto/geeksbot:$IMAGE_TAG .
- name: Install doctl
uses: digitalocean/action-doctl@v2
with: with:
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }} version: latest
- name: Login to DigitalOcean Container Registry with short-lived credentials - name: Docker Login
run: doctl registry login --expiry-seconds 600 # You may pin to the exact commit or the version.
# uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9
uses: docker/login-action@v1.10.0
with:
registry: ${{ secrets.DR_URL }}
# Username used to log against the Docker registry
username: ${{ secrets.DH_USERNAME }}
# Password or personal access token used to log against the Docker registry
password: ${{ secrets.DH_PASSWORD }}
# Log out from the Docker registry at the end of a job
logout: true
- name: Push image to DigitalOcean Container Registry - name: Docker Build & Push
run: docker push registry.digitalocean.com/djpianalto/geeksbot:$IMAGE_TAG
env: env:
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }} IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
run: |
docker buildx build --push \
--tag ${{ secrets.DR_URL }}/geeksbot:$IMAGE_TAG \
--platform linux/amd64,linux/arm/v7,linux/arm64 .
- name: Update deployment file - name: Update deployment file
run: TAG=${{ steps.get_version.outputs.version-without-v }} && sed -i 's|<IMAGE>|registry.digitalocean.com/djpianalto/geeksbot:'${TAG}'|' $GITHUB_WORKSPACE/deployment.yml run: TAG=${{ steps.get_version.outputs.version-without-v }} && sed -i 's|<IMAGE>|${{ secrets.DR_URL }}/geeksbot:'${TAG}'|' $GITHUB_WORKSPACE/deployment.yml
- name: Save DigitalOcean kubeconfig with short-lived credentials - uses: azure/k8s-set-context@v1
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 discord-bots with:
method: kubeconfig
kubeconfig: ${{ secrets.KUBE_CONFIG }}
id: setcontext
- name: Deploy to DigitalOcean Kubernetes - name: Deploy to Kubernetes
run: kubectl apply -f $GITHUB_WORKSPACE/deployment.yml run: kubectl apply -f $GITHUB_WORKSPACE/deployment.yml
- name: Verify deployment - name: Verify deployment
run: kubectl rollout status deployment/geeksbot run: kubectl rollout status -n discord-bots deployment/geeksbot

View File

@ -28,7 +28,7 @@ func main() {
} }
database.ConnectDatabase(os.Getenv("DATABASE_URL")) database.ConnectDatabase(os.Getenv("DATABASE_URL"))
database.RunMigrations() //database.RunMigrations()
services.InitializeServices() services.InitializeServices()
owners := []string{ owners := []string{

View File

@ -2,7 +2,7 @@ apiVersion: apps/v1
kind: Deployment kind: Deployment
metadata: metadata:
name: geeksbot name: geeksbot
namespace: default namespace: discord-bots
labels: labels:
app: geeksbot app: geeksbot
spec: spec:
@ -21,8 +21,42 @@ spec:
app: geeksbot app: geeksbot
spec: spec:
containers: containers:
- name: pgbouncer
image: timoha/pgbouncer:1.15.0
resources:
requests:
memory: "256Mi"
cpu: "0.5"
limits:
memory: "512Mi"
cpu: "1"
env:
- name: DATABASE_URL
valueFrom:
secretKeyRef:
name: geeksbot
key: pgbouncer_url
- name: SERVER_TLS_SSLMODE
valueFrom:
secretKeyRef:
name: geeksbot
key: pgbouncer_ssl
- name: AUTH_TYPE
valueFrom:
secretKeyRef:
name: geeksbot
key: pgbouncer_auth
ports:
- containerPort: 5432
- name: geeksbot - name: geeksbot
image: <IMAGE> image: <IMAGE>
resources:
requests:
memory: "512Mi"
cpu: "1"
limits:
memory: "1Gi"
cpu: "2"
env: env:
- name: DATABASE_URL - name: DATABASE_URL
valueFrom: valueFrom:
@ -34,3 +68,5 @@ spec:
secretKeyRef: secretKeyRef:
name: geeksbot name: geeksbot
key: discord_token key: discord_token
imagePullSecrets:
- name: registry-1

View File

@ -172,7 +172,7 @@ func broadcast(ctx disgoman.Context, server geeksbot.Server, message string) {
return return
} }
log.Printf("%T - %#v", response, response) log.Printf("%T - %#v", response, response)
if strings.Contains(response, "Server recieved, But no response!!") { if strings.Contains(response, "Server received, But no response!!") {
_, _ = ctx.Session.ChannelMessageEdit(ctx.Channel.ID, msg.ID, _, _ = ctx.Session.ChannelMessageEdit(ctx.Channel.ID, msg.ID,
fmt.Sprintf("**%s Broadcast Successful**", server.Name), fmt.Sprintf("**%s Broadcast Successful**", server.Name),
) )