mirror of
https://github.com/ghndrx/k8s-game-2048.git
synced 2026-02-10 14:54:59 +00:00
Add SSL configuration and build workflow
- Add build-image.yml workflow for automated builds to GHCR - Add SSL certificates and domain configuration for HTTPS - Update services to use ghcr.io/ghndrx/k8s-game-2048:latest with imagePullPolicy: Always - Configure Kourier for SSL redirect and domain claims - Enable HTTPS for all environments: dev, staging, prod
This commit is contained in:
51
.github/workflows/build-image.yml
vendored
Normal file
51
.github/workflows/build-image.yml
vendored
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
name: Build and Push Image
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ main, develop ]
|
||||||
|
pull_request:
|
||||||
|
branches: [ main, develop ]
|
||||||
|
|
||||||
|
env:
|
||||||
|
REGISTRY: ghcr.io
|
||||||
|
IMAGE_NAME: ghndrx/k8s-game-2048
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
packages: write
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Log in to Container Registry
|
||||||
|
uses: docker/login-action@v3
|
||||||
|
with:
|
||||||
|
registry: ${{ env.REGISTRY }}
|
||||||
|
username: ${{ github.actor }}
|
||||||
|
password: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
|
- name: Extract metadata
|
||||||
|
id: meta
|
||||||
|
uses: docker/metadata-action@v5
|
||||||
|
with:
|
||||||
|
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
||||||
|
tags: |
|
||||||
|
type=ref,event=branch
|
||||||
|
type=ref,event=pr
|
||||||
|
type=sha,prefix={{branch}}-
|
||||||
|
type=raw,value=latest,enable={{is_default_branch}}
|
||||||
|
|
||||||
|
- name: Build and push Docker image
|
||||||
|
uses: docker/build-push-action@v5
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
tags: ${{ steps.meta.outputs.tags }}
|
||||||
|
labels: ${{ steps.meta.outputs.labels }}
|
||||||
|
|
||||||
|
- name: Image digest
|
||||||
|
run: echo "Image pushed with digest ${{ steps.build.outputs.digest }}"
|
||||||
20
manifests/cluster-domain-claims.yaml
Normal file
20
manifests/cluster-domain-claims.yaml
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
apiVersion: networking.internal.knative.dev/v1alpha1
|
||||||
|
kind: ClusterDomainClaim
|
||||||
|
metadata:
|
||||||
|
name: 2048-dev.wa.darknex.us
|
||||||
|
spec:
|
||||||
|
namespace: game-2048-dev
|
||||||
|
---
|
||||||
|
apiVersion: networking.internal.knative.dev/v1alpha1
|
||||||
|
kind: ClusterDomainClaim
|
||||||
|
metadata:
|
||||||
|
name: 2048-staging.wa.darknex.us
|
||||||
|
spec:
|
||||||
|
namespace: game-2048-staging
|
||||||
|
---
|
||||||
|
apiVersion: networking.internal.knative.dev/v1alpha1
|
||||||
|
kind: ClusterDomainClaim
|
||||||
|
metadata:
|
||||||
|
name: 2048.wa.darknex.us
|
||||||
|
spec:
|
||||||
|
namespace: game-2048-prod
|
||||||
@@ -6,14 +6,6 @@ metadata:
|
|||||||
labels:
|
labels:
|
||||||
app: game-2048
|
app: game-2048
|
||||||
environment: development
|
environment: development
|
||||||
annotations:
|
|
||||||
# Scale to zero configuration
|
|
||||||
autoscaling.knative.dev/minScale: "0"
|
|
||||||
autoscaling.knative.dev/maxScale: "10"
|
|
||||||
# Scale down to zero after 30 seconds of no traffic
|
|
||||||
autoscaling.knative.dev/scaleDownDelay: "30s"
|
|
||||||
# Target concurrency per pod
|
|
||||||
autoscaling.knative.dev/target: "100"
|
|
||||||
spec:
|
spec:
|
||||||
template:
|
template:
|
||||||
metadata:
|
metadata:
|
||||||
@@ -30,6 +22,7 @@ spec:
|
|||||||
containers:
|
containers:
|
||||||
- name: game-2048
|
- name: game-2048
|
||||||
image: ghcr.io/ghndrx/k8s-game-2048:latest
|
image: ghcr.io/ghndrx/k8s-game-2048:latest
|
||||||
|
imagePullPolicy: Always
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 8080
|
- containerPort: 8080
|
||||||
protocol: TCP
|
protocol: TCP
|
||||||
@@ -45,7 +38,7 @@ spec:
|
|||||||
memory: 256Mi
|
memory: 256Mi
|
||||||
readinessProbe:
|
readinessProbe:
|
||||||
httpGet:
|
httpGet:
|
||||||
path: /health
|
path: /
|
||||||
port: 8080
|
port: 8080
|
||||||
initialDelaySeconds: 5
|
initialDelaySeconds: 5
|
||||||
periodSeconds: 10
|
periodSeconds: 10
|
||||||
|
|||||||
8
manifests/knative-domain-config.yaml
Normal file
8
manifests/knative-domain-config.yaml
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: config-domain
|
||||||
|
namespace: knative-serving
|
||||||
|
data:
|
||||||
|
wa.darknex.us: ""
|
||||||
|
autocreate-cluster-domain-claims: "true"
|
||||||
15
manifests/kourier-ssl-config.yaml
Normal file
15
manifests/kourier-ssl-config.yaml
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: config-kourier
|
||||||
|
namespace: knative-serving
|
||||||
|
data:
|
||||||
|
_example: |
|
||||||
|
################################
|
||||||
|
# #
|
||||||
|
# EXAMPLE CONFIGURATION #
|
||||||
|
# #
|
||||||
|
################################
|
||||||
|
enable-service-links: "false"
|
||||||
|
# Enable automatic HTTP to HTTPS redirect
|
||||||
|
ssl-redirect: "true"
|
||||||
@@ -6,14 +6,6 @@ metadata:
|
|||||||
labels:
|
labels:
|
||||||
app: game-2048
|
app: game-2048
|
||||||
environment: production
|
environment: production
|
||||||
annotations:
|
|
||||||
# Scale to zero configuration
|
|
||||||
autoscaling.knative.dev/minScale: "0"
|
|
||||||
autoscaling.knative.dev/maxScale: "50"
|
|
||||||
# Scale down to zero after 5 minutes of no traffic (longer for production)
|
|
||||||
autoscaling.knative.dev/scaleDownDelay: "300s"
|
|
||||||
# Target concurrency per pod
|
|
||||||
autoscaling.knative.dev/target: "100"
|
|
||||||
spec:
|
spec:
|
||||||
template:
|
template:
|
||||||
metadata:
|
metadata:
|
||||||
@@ -29,7 +21,8 @@ spec:
|
|||||||
spec:
|
spec:
|
||||||
containers:
|
containers:
|
||||||
- name: game-2048
|
- name: game-2048
|
||||||
image: ghcr.io/ghndrx/k8s-game-2048:v1.0.0
|
image: ghcr.io/ghndrx/k8s-game-2048:latest
|
||||||
|
imagePullPolicy: Always
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 8080
|
- containerPort: 8080
|
||||||
protocol: TCP
|
protocol: TCP
|
||||||
@@ -45,7 +38,7 @@ spec:
|
|||||||
memory: 1Gi
|
memory: 1Gi
|
||||||
readinessProbe:
|
readinessProbe:
|
||||||
httpGet:
|
httpGet:
|
||||||
path: /health
|
path: /
|
||||||
port: 8080
|
port: 8080
|
||||||
initialDelaySeconds: 5
|
initialDelaySeconds: 5
|
||||||
periodSeconds: 10
|
periodSeconds: 10
|
||||||
|
|||||||
56
manifests/ssl-certificate.yaml
Normal file
56
manifests/ssl-certificate.yaml
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
apiVersion: cert-manager.io/v1
|
||||||
|
kind: ClusterIssuer
|
||||||
|
metadata:
|
||||||
|
name: letsencrypt-prod
|
||||||
|
spec:
|
||||||
|
acme:
|
||||||
|
server: https://acme-v02.api.letsencrypt.org/directory
|
||||||
|
email: admin@hndrx.co
|
||||||
|
privateKeySecretRef:
|
||||||
|
name: letsencrypt-prod
|
||||||
|
solvers:
|
||||||
|
- http01:
|
||||||
|
ingress:
|
||||||
|
class: nginx
|
||||||
|
- http01:
|
||||||
|
ingress:
|
||||||
|
class: nginx
|
||||||
|
---
|
||||||
|
apiVersion: cert-manager.io/v1
|
||||||
|
kind: Certificate
|
||||||
|
metadata:
|
||||||
|
name: game-2048-dev-cert
|
||||||
|
namespace: knative-serving
|
||||||
|
spec:
|
||||||
|
secretName: game-2048-dev-cert-secret
|
||||||
|
issuerRef:
|
||||||
|
name: letsencrypt-prod
|
||||||
|
kind: ClusterIssuer
|
||||||
|
dnsNames:
|
||||||
|
- "2048-dev.wa.darknex.us"
|
||||||
|
---
|
||||||
|
apiVersion: cert-manager.io/v1
|
||||||
|
kind: Certificate
|
||||||
|
metadata:
|
||||||
|
name: game-2048-staging-cert
|
||||||
|
namespace: knative-serving
|
||||||
|
spec:
|
||||||
|
secretName: game-2048-staging-cert-secret
|
||||||
|
issuerRef:
|
||||||
|
name: letsencrypt-prod
|
||||||
|
kind: ClusterIssuer
|
||||||
|
dnsNames:
|
||||||
|
- "2048-staging.wa.darknex.us"
|
||||||
|
---
|
||||||
|
apiVersion: cert-manager.io/v1
|
||||||
|
kind: Certificate
|
||||||
|
metadata:
|
||||||
|
name: game-2048-prod-cert
|
||||||
|
namespace: knative-serving
|
||||||
|
spec:
|
||||||
|
secretName: game-2048-prod-cert-secret
|
||||||
|
issuerRef:
|
||||||
|
name: letsencrypt-prod
|
||||||
|
kind: ClusterIssuer
|
||||||
|
dnsNames:
|
||||||
|
- "2048.wa.darknex.us"
|
||||||
@@ -6,14 +6,6 @@ metadata:
|
|||||||
labels:
|
labels:
|
||||||
app: game-2048
|
app: game-2048
|
||||||
environment: staging
|
environment: staging
|
||||||
annotations:
|
|
||||||
# Scale to zero configuration
|
|
||||||
autoscaling.knative.dev/minScale: "0"
|
|
||||||
autoscaling.knative.dev/maxScale: "20"
|
|
||||||
# Scale down to zero after 60 seconds of no traffic (longer for staging)
|
|
||||||
autoscaling.knative.dev/scaleDownDelay: "60s"
|
|
||||||
# Target concurrency per pod
|
|
||||||
autoscaling.knative.dev/target: "100"
|
|
||||||
spec:
|
spec:
|
||||||
template:
|
template:
|
||||||
metadata:
|
metadata:
|
||||||
@@ -29,7 +21,8 @@ spec:
|
|||||||
spec:
|
spec:
|
||||||
containers:
|
containers:
|
||||||
- name: game-2048
|
- name: game-2048
|
||||||
image: ghcr.io/ghndrx/k8s-game-2048:staging
|
image: ghcr.io/ghndrx/k8s-game-2048:latest
|
||||||
|
imagePullPolicy: Always
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 8080
|
- containerPort: 8080
|
||||||
protocol: TCP
|
protocol: TCP
|
||||||
@@ -45,7 +38,7 @@ spec:
|
|||||||
memory: 512Mi
|
memory: 512Mi
|
||||||
readinessProbe:
|
readinessProbe:
|
||||||
httpGet:
|
httpGet:
|
||||||
path: /health
|
path: /
|
||||||
port: 8080
|
port: 8080
|
||||||
initialDelaySeconds: 5
|
initialDelaySeconds: 5
|
||||||
periodSeconds: 10
|
periodSeconds: 10
|
||||||
|
|||||||
Reference in New Issue
Block a user