feat: add Docker build and deployment workflow
This commit is contained in:
@@ -34,7 +34,23 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
cd ${{ gitea.workspace }}
|
cd ${{ gitea.workspace }}
|
||||||
go test -cover ./...
|
go test -cover ./...
|
||||||
|
- name: Go build
|
||||||
|
run: |
|
||||||
|
cd ${{ gitea.workspace }}
|
||||||
|
go build -ldflags "-X main.version=1.0.0-${{ gitea.sha }}" -o helloapp .
|
||||||
- name: Check Docker
|
- name: Check Docker
|
||||||
run: |
|
run: |
|
||||||
docker --version
|
docker --version
|
||||||
|
- name: Build Docker image
|
||||||
|
run: |
|
||||||
|
cd ${{ gitea.workspace }}
|
||||||
|
docker build -t localhost:8180/k8s-example/k8s-example:${{ gitea.sha }} .
|
||||||
|
- name: Push Docker image to local registry
|
||||||
|
run: |
|
||||||
|
docker push localhost:8180/k8s-example/k8s-example:${{ gitea.sha }}
|
||||||
|
- name: Deploy to Kubernetes
|
||||||
|
run: |
|
||||||
|
cd ${{ gitea.workspace }}
|
||||||
|
sed -i "s|localhost:8180/k8s-example/k8s-example:latest|localhost:8180/k8s-example/k8s-example:${{ gitea.sha }}|g" .gitea/workflows/deploy.yaml
|
||||||
|
kubectl apply -f .gitea/workflows/deploy.yaml
|
||||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||||
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,2 +1,4 @@
|
|||||||
*.exe
|
*.exe
|
||||||
*.prof
|
*.prof
|
||||||
|
certs/*
|
||||||
|
helloapp
|
||||||
7
Dockerfile
Normal file
7
Dockerfile
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
FROM ubuntu:ci
|
||||||
|
|
||||||
|
RUN mkdir -p /var/deploy
|
||||||
|
|
||||||
|
COPY helloapp /var/deploy/helloapp
|
||||||
|
|
||||||
|
CMD ["/var/deploy/helloapp"]
|
||||||
38
deployment.yaml
Normal file
38
deployment.yaml
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: k8s-example
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: k8s-example
|
||||||
|
ports:
|
||||||
|
- port: 8800
|
||||||
|
targetPort: 8800
|
||||||
|
type: LoadBalancer
|
||||||
|
---
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: k8s-example
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: k8s-example
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: k8s-example
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: k8s-example
|
||||||
|
image: localhost:8180/k8s-example/k8s-example:latest
|
||||||
|
imagePullPolicy: IfNotPresent
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
memory: "128Mi"
|
||||||
|
cpu: "500m"
|
||||||
|
limits:
|
||||||
|
memory: "128Mi"
|
||||||
|
cpu: "500m"
|
||||||
|
ports:
|
||||||
|
- containerPort: 8800
|
||||||
7
main.go
7
main.go
@@ -1,12 +1,19 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"k8s-example/hello"
|
"k8s-example/hello"
|
||||||
"net/http"
|
"net/http"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
version = "1.0.0-local"
|
||||||
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
http.HandleFunc("/hello", hello.Handler)
|
http.HandleFunc("/hello", hello.Handler)
|
||||||
|
|
||||||
|
fmt.Println("server on :8800, version:", version)
|
||||||
err := http.ListenAndServe(":8800", nil)
|
err := http.ListenAndServe(":8800", nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
|||||||
Reference in New Issue
Block a user