init
This commit is contained in:
0
docker/docker-compose
Normal file
0
docker/docker-compose
Normal 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
|
||||
69
docker/docker-compose-elk.yml
Normal file
69
docker/docker-compose-elk.yml
Normal 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
|
||||
25
docker/docker-compose-gitea.yml
Normal file
25
docker/docker-compose-gitea.yml
Normal 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
|
||||
@@ -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
|
||||
@@ -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
|
||||
@@ -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: []
|
||||
Reference in New Issue
Block a user