This commit is contained in:
Waloshi6
2026-01-27 17:34:16 +01:00
parent 4c3bd195b7
commit c8204829e9
237 changed files with 3542 additions and 1737 deletions

0
docker/cd Normal file
View File

0
docker/docker-compose Normal file
View File

View File

@@ -1,32 +1,39 @@
services:
db:
image: postgres:15-alpine
container_name: devops-db
restart: unless-stopped
environment:
POSTGRES_DB: devopsdb
POSTGRES_USER: devopsuser
POSTGRES_PASSWORD: devopspass
volumes:
- db-data:/var/lib/postgresql/data
- ./init:/docker-entrypoint-initdb.d
ports:
- "5432:5432"
healthcheck:
test: ["CMD-SHELL", "pg_isready -U devopsuser -d devopsdb"]
interval: 10s
timeout: 5s
retries: 5
networks:
- devops-network
labels:
- "com.devops.description=PostgreSQL Database"
- "com.devops.type=database"
volumes:
db-data:
driver: local
networks:
devops-network:
x-logging: &default-logging
driver: fluentd
options:
fluentd-address: localhost:24224
tag: devops.*
services:
db:
image: postgres:15-alpine
container_name: devops-db
restart: unless-stopped
environment:
POSTGRES_DB: devopsdb
POSTGRES_USER: devopsuser
POSTGRES_PASSWORD: devopspass
volumes:
- db-data:/var/lib/postgresql/data
- ./postgresql:/docker-entrypoint-initdb.d
ports:
- "5432:5432"
healthcheck:
test: ["CMD-SHELL", "pg_isready -U devopsuser -d devopsdb"]
interval: 10s
timeout: 5s
retries: 5
networks:
- devops-network
labels:
- "com.devops.description=PostgreSQL Database"
- "com.devops.type=database"
logging: *default-logging
volumes:
db-data:
driver: local
networks:
devops-network:
external: true

View File

@@ -0,0 +1,69 @@
services:
elasticsearch:
image: docker.elastic.co/elasticsearch/elasticsearch:8.17.0
container_name: elasticsearch
environment:
- node.name=elasticsearch
- discovery.type=single-node
- bootstrap.memory_lock=true
- xpack.security.enabled=false
ulimits:
memlock:
soft: -1
hard: -1
volumes:
- elasticsearch-data:/usr/share/elasticsearch/data
ports:
- "9200:9200"
networks:
- elk
kibana:
image: docker.elastic.co/kibana/kibana:8.17.0
container_name: kibana
environment:
- SERVER_HOST=0.0.0.0
- ELASTICSEARCH_HOSTS=http://elasticsearch:9200
ports:
- "5601:5601"
networks:
- elk
depends_on:
- elasticsearch
logstash:
image: docker.elastic.co/logstash/logstash:8.17.0
container_name: logstash
environment:
- LS_JAVA_OPTS=-Xms512m -Xmx512m
volumes:
- /mnt/c/DevOpsProject/monitoring/elklogs/logstash/config:/usr/share/logstash/pipeline:ro
- /mnt/c/DevOpsProject/monitoring/elklogs/logstash/config/jvm.options:/usr/share/logstash/config/jvm.options:ro
ports:
- "5044:5044"
networks:
- elk
depends_on:
- elasticsearch
filebeat:
image: docker.elastic.co/beats/filebeat:8.17.0
container_name: filebeat
user: root
command: filebeat -e --strict.perms=false
volumes:
- /var/lib/docker/containers:/var/lib/docker/containers:ro
- /var/run/docker.sock:/var/run/docker.sock:ro
- ../monitoring/elklogs/filebeat/filebeat.yml:/usr/share/filebeat/filebeat.yml:ro
networks:
- elk
depends_on:
- elasticsearch
volumes:
elasticsearch-data:
driver: local
networks:
elk:
driver: bridge

View File

@@ -0,0 +1,25 @@
x-logging: &default-logging
driver: fluentd
options:
fluentd-address: localhost:24224
tag: devops.*
services:
gitea:
image: gitea/gitea:latest
container_name: gitea
ports:
- "3001:3000"
- "2222:22"
volumes:
- ../gitea/gitea-data:/data
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
restart: unless-stopped
networks:
- devops-network
logging: *default-logging
networks:
devops-network:
external: true

View File

@@ -1,19 +1,25 @@
services:
nginx:
image: nginx:latest
restart: unless-stopped
ports:
- "80:80"
- "443:443"
volumes:
- C:\DevOpsProject\kubernetes\manifests\nginx\nginx.conf:/etc/nginx/nginx.conf:ro
- C:\DevOpsProject\kubernetes\manifests\nginx\certs:/etc/nginx/certs:ro
depends_on:
- app
networks:
- devops-network
command: nginx -g "daemon off;"
networks:
devops-network:
external: true
x-logging: &default-logging
driver: fluentd
options:
fluentd-address: localhost:24224
tag: devops.*
services:
nginx:
image: nginx:latest
restart: unless-stopped
ports:
- "80:80"
- "443:443"
volumes:
- C:\DevOpsProject\kubernetes\manifests\nginx\nginx.conf:/etc/nginx/nginx.conf:ro
- C:\DevOpsProject\kubernetes\manifests\nginx\certs:/etc/nginx/certs:ro
networks:
- devops-network
command: nginx -g "daemon off;"
logging: *default-logging
networks:
devops-network:
external: true

View File

@@ -1,113 +1,112 @@
services:
# Application principale
app:
build:
context: ..
dockerfile: src/app/Dockerfile
container_name: devops-app
ports:
- "8000:8000"
environment:
- ENV=development
- HOSTNAME=devops-local
volumes:
- ../src/app:/app
- app-logs:/app/logs
networks:
- devops-network
restart: unless-stopped
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:8000/health"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
labels:
- "com.devops.description=Application FastAPI"
- "prometheus.scrape=true"
- "prometheus.port=8000"
- "prometheus.path=/metrics"
# Prometheus pour le monitoring
prometheus:
image: prom/prometheus:v2.47.2
container_name: devops-prometheus
ports:
- "9090:9090"
volumes:
- ./prometheus.yml:/etc/prometheus/prometheus.yml:ro
- prometheus-data:/prometheus
command:
- '--config.file=/etc/prometheus/prometheus.yml'
- '--storage.tsdb.path=/prometheus'
- '--web.console.libraries=/etc/prometheus/console_libraries'
- '--web.console.templates=/etc/prometheus/consoles'
- '--storage.tsdb.retention.time=200h'
- '--web.enable-lifecycle'
networks:
- devops-network
restart: unless-stopped
depends_on:
- app
# Grafana pour les dashboards
grafana:
image: grafana/grafana:10.2.0
container_name: devops-grafana
ports:
- "3000:3000"
environment:
- GF_SECURITY_ADMIN_PASSWORD=admin123
- GF_SECURITY_ADMIN_USER=admin
- GF_INSTALL_PLUGINS=grafana-piechart-panel,grafana-clock-panel
- GF_USERS_ALLOW_SIGN_UP=false
- GF_SERVER_DOMAIN=localhost
- TZ=Europe/Paris
volumes:
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
- grafana-data:/var/lib/grafana
- ./grafana-dashboards:/etc/grafana/provisioning/dashboards
- ./grafana-datasources:/etc/grafana/provisioning/datasources
networks:
- devops-network
restart: unless-stopped
depends_on:
- prometheus
# Portainer pour gérer Docker
portainer:
image: portainer/portainer-ce:latest
container_name: devops-portainer
ports:
- "9000:9000"
- "9443:9443"
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
- portainer-data:/data
networks:
- devops-network
restart: unless-stopped
command: -H unix:///var/run/docker.sock
# Inclusion du service Nginx à partir du fichier docker-compose-nginx.yml
nginx:
depends_on:
- app
networks:
- devops-network
networks:
devops-network:
driver: bridge
name: devops-network
volumes:
prometheus-data:
name: prometheus-data
grafana-data:
name: grafana-data
portainer-data:
name: portainer-data
app-logs:
name: app-logs
x-logging: &default-logging
driver: fluentd
options:
fluentd-address: localhost:24224
tag: devops.*
services:
app:
build:
context: ..
dockerfile: src/app/Dockerfile
container_name: devops-app
ports:
- "8000:8000"
environment:
- ENV=development
- HOSTNAME=devops-local
volumes:
- ../src/app:/app
- app-logs:/app/logs
networks:
- devops-network
restart: unless-stopped
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:8000/health"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
labels:
- "com.devops.description=Application FastAPI"
- "prometheus.scrape=true"
- "prometheus.port=8000"
- "prometheus.path=/metrics"
logging: *default-logging
prometheus:
image: prom/prometheus:v2.47.2
container_name: devops-prometheus
ports:
- "9090:9090"
volumes:
- ../config/prometheus.yml:/etc/prometheus/prometheus.yml:ro
- prometheus-data:/prometheus
command:
- '--config.file=/etc/prometheus/prometheus.yml'
- '--storage.tsdb.path=/prometheus'
- '--web.console.libraries=/etc/prometheus/console_libraries'
- '--web.console.templates=/etc/prometheus/consoles'
- '--storage.tsdb.retention.time=200h'
- '--web.enable-lifecycle'
networks:
- devops-network
restart: unless-stopped
depends_on:
- app
logging: *default-logging
grafana:
image: grafana/grafana:10.2.0
container_name: devops-grafana
ports:
- "3000:3000"
environment:
- GF_SECURITY_ADMIN_PASSWORD=admin123
- GF_SECURITY_ADMIN_USER=admin
- GF_INSTALL_PLUGINS=grafana-piechart-panel,grafana-clock-panel
- GF_USERS_ALLOW_SIGN_UP=false
- GF_SERVER_DOMAIN=localhost
- TZ=Europe/Paris
volumes:
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
- grafana-data:/var/lib/grafana
- ../monitoring/grafana-dashboards:/etc/grafana/provisioning/dashboards
- ../monitoring/grafana-datasources:/etc/grafana/provisioning/datasources
networks:
- devops-network
restart: unless-stopped
depends_on:
- prometheus
logging: *default-logging
portainer:
image: portainer/portainer-ce:latest
container_name: devops-portainer
ports:
- "9000:9000"
- "9443:9443"
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
- portainer-data:/data
networks:
- devops-network
restart: unless-stopped
command: -H unix:///var/run/docker.sock
logging: *default-logging
networks:
devops-network:
driver: bridge
name: devops-network
volumes:
prometheus-data:
name: prometheus-data
grafana-data:
name: grafana-data
portainer-data:
name: portainer-data
app-logs:
name: app-logs

View File

@@ -1,41 +0,0 @@
global:
scrape_interval: 15s
evaluation_interval: 15s
external_labels:
cluster: 'windows-devops'
environment: 'development'
# Règles d'alerte
rule_files:
# - "alerts.yml"
# Configuration de scraping
scrape_configs:
# Scraper l'application FastAPI
- job_name: 'fastapi-app'
static_configs:
- targets: ['app:8000']
labels:
app: 'devops-app'
component: 'backend'
tier: 'application'
# Scraper Prometheus lui-même
- job_name: 'prometheus'
static_configs:
- targets: ['localhost:9090']
labels:
component: 'monitoring'
# Découverte de service Docker
- job_name: 'docker'
static_configs:
- targets: ['host.docker.internal:9323']
metrics_path: /metrics
scheme: http
# Alerting (exemple)
# alerting:
# alertmanagers:
# - static_configs:
# - targets: []