add drone and k8s configs
Some checks failed
Deploy to pages / build (push) Has been cancelled

This commit is contained in:
Николай Вигдоров
2025-06-28 21:32:25 +03:00
parent d8ed6cfdd7
commit 3dbee0781a
5 changed files with 139 additions and 0 deletions

81
.drone.yml Normal file
View File

@ -0,0 +1,81 @@
kind: pipeline
type: kubernetes
name: deploy-frontend
# Триггеры: запускать на push в ветки main и develop
trigger:
branch:
- master
- develop
event:
- push
steps:
# --- Шаг 1: Сборка и отправка образа в Harbor ---
# Этот шаг выполняется для любой из веток (main или develop)
- name: build-and-push
image: plugins/docker
settings:
# Укажите ваш домен Harbor
registry: ci.vigdorov.ru
# Имя репозитория в Harbor (например, в проекте library)
repo: ci.vigdorov.ru/library/examples-for-kids-app
# Тег будет равен первым 7 символам хеша коммита (например, a1b2c3d)
tags:
- ${DRONE_COMMIT_SHA:0:7}
# Используем секреты, которые мы создали в Drone
username:
from_secret: HARBOR_USER
password:
from_secret: HARBOR_PASSWORD
# --- Шаг 2: Развертывание в DEV-окружение ---
- name: deploy-dev
image: alpine/k8s:1.28.2 # Образ с kubectl и другими утилитами
# Запускать этот шаг ТОЛЬКО для ветки 'develop'
trigger:
branch:
- develop
environment:
# Используем секрет с kubeconfig
KUBECONFIG:
from_secret: KUBE_CONFIG
commands:
# Готовим переменные для dev-окружения
- export APP_NAMESPACE="dev-ns" # Будем деплоить в отдельный неймспейс
- export HOSTNAME="dev.examples-for-kids.vigdorov.ru"
- export IMAGE_TAG="${DRONE_COMMIT_SHA:0:7}"
- export IMAGE_NAME="ci.vigdorov.ru/library/examples-for-kids-app"
- export SECRET_NAME="dev-test-tls"
# Создаем неймспейс, если его нет
- kubectl create namespace $APP_NAMESPACE --dry-run=client -o yaml | kubectl apply -f -
# Заменяем метки в шаблонах на реальные значения и применяем
- sed -e "s|__IMAGE__|$IMAGE_NAME:$IMAGE_TAG|g" k8s/deployment.yaml | kubectl apply -n $APP_NAMESPACE -f -
- kubectl apply -n $APP_NAMESPACE -f k8s/service.yaml
- sed -e "s|__HOSTNAME__|$HOSTNAME|g" -e "s|__SECRET_NAME__|$SECRET_NAME|g" k8s/ingress.yaml | kubectl apply -n $APP_NAMESPACE -f -
- echo "Deployed to DEV: https://$HOSTNAME"
# --- Шаг 3: Развертывание в PROD-окружение ---
- name: deploy-prod
image: alpine/k8s:1.28.2
# Запускать этот шаг ТОЛЬКО для ветки 'main'
trigger:
branch:
- master
environment:
KUBECONFIG:
from_secret: KUBE_CONFIG
commands:
# Готовим переменные для prod-окружения
- export APP_NAMESPACE="prod-ns"
- export HOSTNAME="examples-for-kids.vigdorov.ru"
- export IMAGE_TAG="${DRONE_COMMIT_SHA:0:7}"
- export IMAGE_NAME="ci.vigdorov.ru/library/examples-for-kids-app"
- export SECRET_NAME="prod-test-tls"
# Создаем неймспейс
- kubectl create namespace $APP_NAMESPACE --dry-run=client -o yaml | kubectl apply -f -
# Разворачиваем приложение
- sed -e "s|__IMAGE__|$IMAGE_NAME:$IMAGE_TAG|g" k8s/deployment.yaml | kubectl apply -n $APP_NAMESPACE -f -
- kubectl apply -n $APP_NAMESPACE -f k8s/service.yaml
- sed -e "s|__HOSTNAME__|$HOSTNAME|g" -e "s|__SECRET_NAME__|$SECRET_NAME|g" k8s/ingress.yaml | kubectl apply -n $APP_NAMESPACE -f -
- echo "Deployed to PROD: https://$HOSTNAME"

1
.gitignore vendored
View File

@ -6,3 +6,4 @@
.dependencies-cache .dependencies-cache
/reports /reports
.DS_Store .DS_Store
.cursor

20
k8s/deployment.yaml Normal file
View File

@ -0,0 +1,20 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: examples-for-kids-app
spec:
replicas: 1
selector:
matchLabels:
app: examples-for-kids-app
template:
metadata:
labels:
app: examples-for-kids-app
spec:
containers:
- name: examples-for-kids-app
# __IMAGE__ - это метка, которую заменит Drone
image: __IMAGE__
ports:
- containerPort: 80

26
k8s/ingress.yaml Normal file
View File

@ -0,0 +1,26 @@
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: examples-for-kids-ingress
annotations:
# Запрашиваем сертификат
cert-manager.io/cluster-issuer: "letsencrypt-prod"
spec:
ingressClassName: traefik
tls:
- hosts:
# __HOSTNAME__ - метка для домена
- __HOSTNAME__
# __SECRET_NAME__ - метка для имени секрета с сертификатом
secretName: __SECRET_NAME__
rules:
- host: __HOSTNAME__
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: examples-for-kids-app-service
port:
number: 80

11
k8s/service.yaml Normal file
View File

@ -0,0 +1,11 @@
apiVersion: v1
kind: Service
metadata:
name: examples-for-kids-app-service
spec:
selector:
app: examples-for-kids-app
ports:
- protocol: TCP
port: 80
targetPort: 80