class: center, middle # Kraken CI ## Architecture --- # Agenda 1. Architecture 2. Workflow --- # Introduction - Kraken composed of: - web UI - several backend services - distributted agents - Backend in Python - UI in Typescript/HTML - Development based on Docker --- # Kraken Architecture data:image/s3,"s3://crabby-images/aa8c8/aa8c884bf1dd46dbcef9bee74b65dd38c62b292c" alt="Kraken Architecture" --- .imgover[data:image/s3,"s3://crabby-images/4359b/4359b1be386e024419b12dbc1521ea1fe55db6f9" alt="Kraken Architecture"] # Web UI - Angular framework - PrimeNG components --- .imgover[data:image/s3,"s3://crabby-images/7e77a/7e77aa8b759dc0b8fc7f4fb3a761c4512acf3283" alt="Kraken Architecture"] # API Server - Serves API requests from: - users (via web UI or programmatically) - other backend services - Serves webhooks - API defined in Swagger --- .imgover[data:image/s3,"s3://crabby-images/11f7c/11f7c700a8f5cd18f73d0f9485408a5663b44a1a" alt="Kraken Architecture"] # Controller - Single instance - Planner - Scheduler - Watchdog - Storage --- .imgover[data:image/s3,"s3://crabby-images/11f7c/11f7c700a8f5cd18f73d0f9485408a5663b44a1a" alt="Kraken Architecture"] # Controller / Planner - Remembers planned job triggers - Fires them at indicated time: - periodically - on given time - according CRON rule --- .imgover[data:image/s3,"s3://crabby-images/11f7c/11f7c700a8f5cd18f73d0f9485408a5663b44a1a" alt="Kraken Architecture"] # Controller / Scheduler - Assigns triggered jobs to idle agents - FIFO --- .imgover[data:image/s3,"s3://crabby-images/11f7c/11f7c700a8f5cd18f73d0f9485408a5663b44a1a" alt="Kraken Architecture"] # Controller / Watchdog - Monitors Runs and their Jobs - Run timeout - Job timeout - Monitors Agents - if not responding then disabled to avoid assigning --- .imgover[data:image/s3,"s3://crabby-images/11f7c/11f7c700a8f5cd18f73d0f9485408a5663b44a1a" alt="Kraken Architecture"] # Controller / Storage - Serves storage for agents - Agents can put or get artifacts --- .imgover[data:image/s3,"s3://crabby-images/a02e2/a02e249ca638b66750cfc4f3809b58f49c0affae" alt="Kraken Architecture"] # RQ - Background tasks - processes results of a job - results history analysis - and more --- .imgover[data:image/s3,"s3://crabby-images/63a3e/63a3ea6ade902ac360b1c9df5c974e7bc3ec8ecb" alt="Kraken Architecture"] # Agent - Agent runs on a host - Jobs are run in executor via tool - Executors - Bare - Docker - LXD --- .imgover[data:image/s3,"s3://crabby-images/63a3e/63a3ea6ade902ac360b1c9df5c974e7bc3ec8ecb" alt="Kraken Architecture"] # Agent / Tool - Run in executor - Provided operations: - shell - git operations - storing/retrieving artifacts - pytest - pylint - ngling - cloc --- .imgover[data:image/s3,"s3://crabby-images/03bff/03bff8ec93c2c3944f16c171763e97bffe3d8ac7" alt="Kraken Architecture"] # ELK - Logstash - backend services and all agents log to Logstash - log entries are assigned to agents/jobs/etc - Elasticsearch - allows querying logs - eg. shows all logs associated with given job or stage - Kibana - UI to Elasticsearch --- .imgover[data:image/s3,"s3://crabby-images/7e93f/7e93fc5d6c84a10de9ae76252f18b7a3c9bd512a" alt="Kraken Architecture"] # PostgreSQL - main database --- .imgover[data:image/s3,"s3://crabby-images/47e9b/47e9bd9759618992a64a1cbf8640ae5325809e9a" alt="Kraken Architecture"] # Kraken Workflow - Planner or UI trigger a Job - Job is scheduled for execution to idle Agent - Agent executes the Job - Agent can store or fetch artifacts from Storage - Whole Job execution log goes to ELK - After completing the Job its results are processed by RQ data:image/s3,"s3://crabby-images/87928/87928b9b48e4504ea37fe420d828b39e7c9c5366" alt="Kraken Workflow"