add build test
Some checks failed
Build and Deploy Backend / build-and-deploy (push) Failing after 6m4s
Some checks failed
Build and Deploy Backend / build-and-deploy (push) Failing after 6m4s
This commit is contained in:
parent
3a8df43de7
commit
ded5be6a05
73
.gitea/workflows/deploy.yaml
Normal file
73
.gitea/workflows/deploy.yaml
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
name: Build and Deploy Backend
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
- master
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-and-deploy:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v2
|
||||||
|
with:
|
||||||
|
config-inline: |
|
||||||
|
[registry."docker.io"]
|
||||||
|
mirrors = ["https://docker.m.daocloud.io", "https://docker.1panel.live", "https://hub.rat.dev"]
|
||||||
|
|
||||||
|
- name: Login to Huawei Cloud SWR
|
||||||
|
uses: docker/login-action@v2
|
||||||
|
with:
|
||||||
|
registry: ${{ secrets.SWR_SERVER }}
|
||||||
|
username: ${{ secrets.SWR_USERNAME }}
|
||||||
|
password: ${{ secrets.SWR_PASSWORD }}
|
||||||
|
|
||||||
|
- name: Build and Push Backend
|
||||||
|
uses: docker/build-push-action@v4
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
provenance: false
|
||||||
|
tags: ${{ secrets.SWR_SERVER }}/${{ secrets.SWR_ORG }}/rtc-backend:latest
|
||||||
|
|
||||||
|
- name: Setup Kubectl
|
||||||
|
run: |
|
||||||
|
curl -LO "https://files.m.daocloud.io/dl.k8s.io/release/v1.28.2/bin/linux/amd64/kubectl"
|
||||||
|
chmod +x kubectl
|
||||||
|
mv kubectl /usr/local/bin/
|
||||||
|
|
||||||
|
- name: Deploy to K3s
|
||||||
|
uses: Azure/k8s-set-context@v3
|
||||||
|
with:
|
||||||
|
method: kubeconfig
|
||||||
|
kubeconfig: ${{ secrets.KUBE_CONFIG }}
|
||||||
|
|
||||||
|
- name: Update K8s Manifests
|
||||||
|
run: |
|
||||||
|
# 1. 判断分支,决定使用哪个配置文件
|
||||||
|
if [[ "${{ github.ref_name }}" == "main" || "${{ github.ref_name }}" == "master" ]]; then
|
||||||
|
echo "Environment: Production"
|
||||||
|
DEPLOY_FILE="k8s/backend-deployment-prod.yaml"
|
||||||
|
INGRESS_FILE="k8s/ingress.yaml"
|
||||||
|
DEPLOY_NAME="rtc-backend"
|
||||||
|
else
|
||||||
|
echo "Environment: Development"
|
||||||
|
DEPLOY_FILE="k8s/backend-deployment-dev.yaml"
|
||||||
|
INGRESS_FILE="k8s/ingress-dev.yaml"
|
||||||
|
DEPLOY_NAME="rtc-backend-dev"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 2. 替换镜像地址
|
||||||
|
sed -i "s|\${CI_REGISTRY_IMAGE}/backend:latest|${{ secrets.SWR_SERVER }}/${{ secrets.SWR_ORG }}/rtc-backend:latest|g" $DEPLOY_FILE
|
||||||
|
|
||||||
|
# 3. 应用配置
|
||||||
|
# kubectl apply -f k8s/redis-deployment.yaml (Cloud Redis used, skipping)
|
||||||
|
kubectl apply -f $DEPLOY_FILE
|
||||||
|
kubectl apply -f $INGRESS_FILE
|
||||||
|
|
||||||
|
kubectl rollout restart deployment/$DEPLOY_NAME
|
||||||
29
Dockerfile
Normal file
29
Dockerfile
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
# Use an official Python runtime as a parent image
|
||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
# Set environment variables
|
||||||
|
ENV PYTHONDONTWRITEBYTECODE=1
|
||||||
|
ENV PYTHONUNBUFFERED=1
|
||||||
|
|
||||||
|
# Set work directory
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
# Install system dependencies
|
||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
|
gcc \
|
||||||
|
default-libmysqlclient-dev \
|
||||||
|
pkg-config \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Install python dependencies
|
||||||
|
COPY requirements.txt /app/
|
||||||
|
RUN pip install --upgrade pip && pip install -r requirements.txt && pip install gunicorn
|
||||||
|
|
||||||
|
# Copy project
|
||||||
|
COPY . /app/
|
||||||
|
|
||||||
|
# Expose port
|
||||||
|
EXPOSE 8000
|
||||||
|
|
||||||
|
# Run entrypoint
|
||||||
|
CMD ["gunicorn", "--bind", "0.0.0.0:8000", "config.wsgi:application"]
|
||||||
81
k8s/backend-deployment-dev.yaml
Normal file
81
k8s/backend-deployment-dev.yaml
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: rtc-backend-dev
|
||||||
|
labels:
|
||||||
|
app: rtc-backend-dev
|
||||||
|
spec:
|
||||||
|
replicas: 1 # 测试环境通常 1 个副本就够了
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: rtc-backend-dev
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: rtc-backend-dev
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: rtc-backend
|
||||||
|
image: ${CI_REGISTRY_IMAGE}/backend:latest
|
||||||
|
imagePullPolicy: Always
|
||||||
|
ports:
|
||||||
|
- containerPort: 8000
|
||||||
|
env:
|
||||||
|
# Database (Test Environment)
|
||||||
|
- name: DB_HOST
|
||||||
|
value: "test-mysql-host" # <--- 请填入测试环境数据库 IP
|
||||||
|
- name: DB_NAME
|
||||||
|
value: "rtc_test" # <--- 测试数据库名
|
||||||
|
- name: DB_USER
|
||||||
|
value: "test_user"
|
||||||
|
- name: DB_PASSWORD
|
||||||
|
value: "test_password"
|
||||||
|
- name: DB_PORT
|
||||||
|
value: "3306"
|
||||||
|
|
||||||
|
# Redis (Test Environment)
|
||||||
|
- name: REDIS_URL
|
||||||
|
value: "redis://:password@test-redis-host:6379/1" # <--- 测试环境 Redis
|
||||||
|
|
||||||
|
# Aliyun OSS (Test)
|
||||||
|
- name: OSS_ACCESS_KEY_ID
|
||||||
|
value: "test_key"
|
||||||
|
- name: OSS_ACCESS_KEY_SECRET
|
||||||
|
value: "test_secret"
|
||||||
|
- name: OSS_BUCKET_NAME
|
||||||
|
value: "qy-rtc"
|
||||||
|
- name: OSS_ENDPOINT
|
||||||
|
value: "oss-cn-beijing.aliyuncs.com"
|
||||||
|
- name: OSS_CUSTOM_DOMAIN
|
||||||
|
value: ""
|
||||||
|
|
||||||
|
# Aliyun Log (If used by app)
|
||||||
|
- name: ALIYUN_LOG_PROJECT
|
||||||
|
value: "toy"
|
||||||
|
- name: ALIYUN_LOG_STORE
|
||||||
|
value: "rtc"
|
||||||
|
- name: ALIYUN_LOG_ENDPOINT
|
||||||
|
value: "cn-guangzhou.log.aliyuncs.com"
|
||||||
|
- name: ALIYUN_LOG_ACCESS_KEY_ID
|
||||||
|
value: "LTAI5tBGAkR2rra2prTAX9yc"
|
||||||
|
- name: ALIYUN_LOG_ACCESS_KEY_SECRET
|
||||||
|
value: "U1z3d0p5saPRD5sCxVooJYSjxSAmKB"
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
memory: "256Mi"
|
||||||
|
cpu: "250m"
|
||||||
|
limits:
|
||||||
|
memory: "1024Mi"
|
||||||
|
cpu: "1000m"
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: rtc-backend-dev
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: rtc-backend-dev
|
||||||
|
ports:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 8000
|
||||||
|
targetPort: 8000
|
||||||
81
k8s/backend-deployment-prod.yaml
Normal file
81
k8s/backend-deployment-prod.yaml
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: rtc-backend
|
||||||
|
labels:
|
||||||
|
app: rtc-backend
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: rtc-backend
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: rtc-backend
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: rtc-backend
|
||||||
|
image: ${CI_REGISTRY_IMAGE}/backend:latest
|
||||||
|
imagePullPolicy: Always
|
||||||
|
ports:
|
||||||
|
- containerPort: 8000
|
||||||
|
env:
|
||||||
|
# Database
|
||||||
|
- name: DB_HOST
|
||||||
|
value: "rm-7xv1uaw910558p1788o.mysql.rds.aliyuncs.com"
|
||||||
|
- name: DB_NAME
|
||||||
|
value: "rtc"
|
||||||
|
- name: DB_USER
|
||||||
|
value: "rtc"
|
||||||
|
- name: DB_PASSWORD
|
||||||
|
value: "JogNQdtrd3WY8CBCAiYfYEGx"
|
||||||
|
- name: DB_PORT
|
||||||
|
value: "3306"
|
||||||
|
|
||||||
|
# Redis
|
||||||
|
- name: REDIS_URL
|
||||||
|
value: "redis://:vAhRnAA6VMco@r-7xvat0vez5clwbzk5vpd.redis.rds.aliyuncs.com:6379/8"
|
||||||
|
|
||||||
|
# Aliyun OSS
|
||||||
|
- name: OSS_ACCESS_KEY_ID
|
||||||
|
value: "LTAI5tBGAkR2rra2prTAX9yc"
|
||||||
|
- name: OSS_ACCESS_KEY_SECRET
|
||||||
|
value: "U1z3d0p5saPRD5sCxVooJYSjxSAmKB"
|
||||||
|
- name: OSS_BUCKET_NAME
|
||||||
|
value: "qy-rtc"
|
||||||
|
- name: OSS_ENDPOINT
|
||||||
|
value: "oss-cn-beijing.aliyuncs.com"
|
||||||
|
- name: OSS_CUSTOM_DOMAIN
|
||||||
|
value: ""
|
||||||
|
|
||||||
|
# Aliyun Log (If used by app)
|
||||||
|
- name: ALIYUN_LOG_PROJECT
|
||||||
|
value: "toy"
|
||||||
|
- name: ALIYUN_LOG_STORE
|
||||||
|
value: "rtc"
|
||||||
|
- name: ALIYUN_LOG_ENDPOINT
|
||||||
|
value: "cn-guangzhou.log.aliyuncs.com"
|
||||||
|
- name: ALIYUN_LOG_ACCESS_KEY_ID
|
||||||
|
value: "LTAI5tBGAkR2rra2prTAX9yc"
|
||||||
|
- name: ALIYUN_LOG_ACCESS_KEY_SECRET
|
||||||
|
value: "U1z3d0p5saPRD5sCxVooJYSjxSAmKB"
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
memory: "256Mi"
|
||||||
|
cpu: "250m"
|
||||||
|
limits:
|
||||||
|
memory: "1024Mi"
|
||||||
|
cpu: "1000m"
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: rtc-backend
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: rtc-backend
|
||||||
|
ports:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 8000
|
||||||
|
targetPort: 8000
|
||||||
18
k8s/ingress-dev.yaml
Normal file
18
k8s/ingress-dev.yaml
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: networking.k8s.io/v1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: rtc-backend-ingress-dev
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/ingress.class: "traefik"
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- host: qiyuan-rtc-dev-api.airlabs.art
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
pathType: Prefix
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: rtc-backend-dev
|
||||||
|
port:
|
||||||
|
number: 8000
|
||||||
18
k8s/ingress.yaml
Normal file
18
k8s/ingress.yaml
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: networking.k8s.io/v1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: rtc-backend-ingress
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/ingress.class: "traefik"
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- host: qiyuan-rtc-api.airlabs.art
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
pathType: Prefix
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: rtc-backend
|
||||||
|
port:
|
||||||
|
number: 8000
|
||||||
Loading…
x
Reference in New Issue
Block a user