Compare commits

..

No commits in common. 'main' and 'golang' have entirely different histories.
main ... golang

@ -10,7 +10,7 @@ on:
jobs: jobs:
build: build:
runs-on: self-hosted runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job # Steps represent a sequence of tasks that will be executed as part of the job
steps: steps:
@ -21,37 +21,29 @@ jobs:
id: get_version id: get_version
uses: battila7/get-version-action@v2.0.0 uses: battila7/get-version-action@v2.0.0
- name: Docker Login - name: Build container image
# You may pin to the exact commit or the version. env:
# uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
uses: docker/login-action@v1.10.0 run: docker build -t registry.digitalocean.com/djpianalto/snowflake-server:$IMAGE_TAG .
- name: Install doctl
uses: digitalocean/action-doctl@v2
with: with:
registry: ${{ secrets.DR_URL }} token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }}
# Username used to log against the Docker registry
username: ${{ secrets.DH_USERNAME }} - name: Login to DigitalOcean Container Registry with short-lived credentials
# Password or personal access token used to log against the Docker registry run: doctl registry login --expiry-seconds 600
password: ${{ secrets.DH_PASSWORD }}
# Log out from the Docker registry at the end of a job - name: Push image to DigitalOcean Container Registry
logout: true
- name: Docker Build & Push
env: env:
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }} IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
run: | run: docker push registry.digitalocean.com/djpianalto/snowflake-server:$IMAGE_TAG
docker build -t ${{ secrets.DR_URL }}/snowflake-server:$IMAGE_TAG .
docker push ${{ secrets.DR_URL }}/snowflake-server:$IMAGE_TAG
sed -i 's|<IMAGE>|${{ secrets.DR_URL }}/snowflake-server:'${IMAGE_TAG}'|' $GITHUB_WORKSPACE/deployment.yml
- name: Kubectl tool installer - name: Update deployment file
uses: Azure/setup-kubectl@v1 run: TAG=${{ steps.get_version.outputs.version-without-v }} && sed -i 's|<IMAGE>|registry.digitalocean.com/djpianalto/snowflake-server:'${TAG}'|' $GITHUB_WORKSPACE/deployment.yml
- name: Kubernetes set context - name: Save DigitalOcean kubeconfig with short-lived credentials
uses: Azure/k8s-set-context@v1.1 run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 discord-bots
with:
# Acceptable values: kubeconfig or service-account or service-principal
method: kubeconfig
# Kubernetes Config
kubeconfig: ${{ secrets.KUBE_CONFIG }}
- name: Deploy to Kubernetes - name: Deploy to DigitalOcean Kubernetes
run: kubectl apply -f $GITHUB_WORKSPACE/deployment.yml run: kubectl apply -f $GITHUB_WORKSPACE/deployment.yml

@ -5,7 +5,6 @@ COPY ./go.mod .
COPY ./go.sum . COPY ./go.sum .
RUN go mod download RUN go mod download
RUN sed -i 's/https/http/' /etc/apk/repositories
RUN apk update RUN apk update
RUN apk add protobuf RUN apk add protobuf

@ -1,9 +1,6 @@
package main package main
import ( import (
"log"
"os"
"strconv"
"sync" "sync"
"github.com/dustinpianalto/snowflake/internal/generator" "github.com/dustinpianalto/snowflake/internal/generator"
@ -13,12 +10,7 @@ import (
func main() { func main() {
workerID, err := strconv.ParseUint(os.Getenv("WORKER_ID"), 10, 64) generator.CreateGenerator(1)
if err != nil {
log.Fatal("Not a valid worker id")
}
generator.CreateGenerator(workerID)
go generator.Generator.Run() go generator.Generator.Run()

@ -2,7 +2,7 @@ kind: Service
apiVersion: v1 apiVersion: v1
metadata: metadata:
name: snowflake-server name: snowflake-server
namespace: default namespace: dca
labels: labels:
environment: production environment: production
spec: spec:
@ -21,39 +21,30 @@ status:
--- ---
apiVersion: apps/v1 apiVersion: v1
kind: Deployment apiVersion: batch/v1beta1
kind: CronJob
metadata: metadata:
name: snowflake-server name: snowflake-server
namespace: default namespace: default
labels: labels:
app: snowflake-server app: snowflake-server
spec: spec:
replicas: 1 schedule: "0 0 * * *"
selector: jobTemplate:
matchLabels:
app: snowflake-server
strategy:
rollingUpdate:
maxSurge: 1
maxUnavailable: 1
minReadySeconds: 30
template:
metadata:
labels:
app: snowflake-server
spec: spec:
containers: template:
- name: snowflake-server spec:
image: <IMAGE> restartPolicy: "OnFailure"
ports: containers:
- containerPort: 50051 - name: snowflake-server
- containerPort: 50052 image: <IMAGE>
env: ports:
- name: WORKER_ID - containerPort: 50051
valueFrom: - containerPort: 50052
secretKeyRef: env:
name: snowflake - name: WORKER_ID
key: worker_id valueFrom:
imagePullSecrets: secretKeyRef:
- name: regcred name: snowflake
key: worker_id

Loading…
Cancel
Save