diff --git a/docker-compose.yaml b/ci/development/docker-compose.yaml similarity index 78% rename from docker-compose.yaml rename to ci/development/docker-compose.yaml index 8d49156..0a16b1b 100644 --- a/docker-compose.yaml +++ b/ci/development/docker-compose.yaml @@ -1,7 +1,7 @@ services: postgres: image: postgres:17-alpine - container_name: boring_postgres + container_name: boring_services_postgres ports: - 5432:5432 environment: @@ -10,25 +10,22 @@ services: - POSTGRES_DB=postgres cache: - container_name: boring_redis + container_name: boring_services_redis image: redis:7.4.1-alpine ports: - '6379:6379' - # command: redis-server --save 20 1 --loglevel warning --requirepass development + command: redis-server --save 20 1 --loglevel warning --requirepass development loki: image: grafana/loki:latest + container_name: boring_services_loki ports: - "9100:3100" command: -config.file=/etc/loki/local-config.yaml - promtail: - image: grafana/promtail:latest - volumes: - - /var/log:/var/log - command: -config.file=/etc/promtail/config.yml - grafana: + image: grafana/grafana:latest + container_name: boring_services_grafana environment: - GF_PATHS_PROVISIONING=/etc/grafana/provisioning - GF_AUTH_ANONYMOUS_ENABLED=true @@ -52,6 +49,5 @@ services: editable: false EOF /run.sh - image: grafana/grafana:latest ports: - "9000:3000" \ No newline at end of file diff --git a/ci/development/grafana/dashboards/api-logs.json b/ci/development/grafana/dashboards/api-logs.json new file mode 100644 index 0000000..2e89de6 --- /dev/null +++ b/ci/development/grafana/dashboards/api-logs.json @@ -0,0 +1,263 @@ +{ + "annotations": { + "list": [ + { + "builtIn": 1, + "datasource": { + "type": "grafana", + "uid": "-- Grafana --" + }, + "enable": true, + "hide": true, + "iconColor": "rgba(0, 211, 255, 1)", + "name": "Annotations & Alerts", + "type": "dashboard" + } + ] + }, + "editable": true, + "fiscalYearStartMonth": 0, + "graphTooltip": 0, + "id": 1, + "links": [], + "panels": [ + { + "collapsed": false, + "gridPos": { + "h": 1, + "w": 24, + "x": 0, + "y": 0 + }, + "id": 6, + "panels": [], + "title": "Service: API", + "type": "row" + }, + { + "datasource": { + "type": "loki", + "uid": "P8E80F9AEF21F6940" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "thresholds" + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "green", + "value": null + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 4, + "x": 0, + "y": 1 + }, + "id": 2, + "options": { + "colorMode": "value", + "graphMode": "none", + "justifyMode": "auto", + "orientation": "auto", + "percentChangeColorMode": "standard", + "reduceOptions": { + "calcs": ["sum"], + "fields": "", + "values": false + }, + "showPercentChange": false, + "textMode": "auto", + "wideLayout": true + }, + "pluginVersion": "11.3.0", + "targets": [ + { + "editorMode": "builder", + "expr": "count(rate({service=\"api\"} | json | status <= 399 [$__auto]))", + "queryType": "range", + "refId": "A" + } + ], + "title": "<= 399", + "type": "stat" + }, + { + "datasource": { + "type": "loki", + "uid": "P8E80F9AEF21F6940" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "thresholds" + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "yellow", + "value": null + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 4, + "x": 4, + "y": 1 + }, + "id": 3, + "options": { + "colorMode": "value", + "graphMode": "none", + "justifyMode": "auto", + "orientation": "auto", + "percentChangeColorMode": "standard", + "reduceOptions": { + "calcs": ["sum"], + "fields": "", + "values": false + }, + "showPercentChange": false, + "textMode": "auto", + "wideLayout": true + }, + "pluginVersion": "11.3.0", + "targets": [ + { + "editorMode": "code", + "expr": "count(rate({service=\"api\"} | json | status >= 400 and status <= 499 [$__auto]))", + "queryType": "range", + "refId": "A" + } + ], + "title": "400 - 499", + "type": "stat" + }, + { + "datasource": { + "type": "loki", + "uid": "P8E80F9AEF21F6940" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "thresholds" + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "red", + "value": null + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 4, + "x": 8, + "y": 1 + }, + "id": 4, + "options": { + "colorMode": "value", + "graphMode": "none", + "justifyMode": "auto", + "orientation": "auto", + "percentChangeColorMode": "standard", + "reduceOptions": { + "calcs": ["sum"], + "fields": "", + "values": false + }, + "showPercentChange": false, + "textMode": "auto", + "wideLayout": true + }, + "pluginVersion": "11.3.0", + "targets": [ + { + "editorMode": "code", + "expr": "count(rate({service=\"api\"} | json | status >= 500 [$__auto]))", + "queryType": "range", + "refId": "A" + } + ], + "title": "400 - 499", + "type": "stat" + }, + { + "datasource": { + "type": "loki", + "uid": "P8E80F9AEF21F6940" + }, + "fieldConfig": { + "defaults": {}, + "overrides": [] + }, + "gridPos": { + "h": 17, + "w": 24, + "x": 0, + "y": 9 + }, + "id": 5, + "options": { + "dedupStrategy": "none", + "enableLogDetails": true, + "prettifyLogMessage": false, + "showCommonLabels": false, + "showLabels": false, + "showTime": true, + "sortOrder": "Descending", + "wrapLogMessage": false + }, + "pluginVersion": "11.3.0", + "targets": [ + { + "editorMode": "builder", + "expr": "{service=\"api\"} | json", + "queryType": "range", + "refId": "A" + } + ], + "title": "Logs", + "type": "logs" + } + ], + "preload": false, + "schemaVersion": 40, + "tags": [], + "templating": { + "list": [] + }, + "time": { + "from": "now-1h", + "to": "now" + }, + "timepicker": {}, + "timezone": "browser", + "title": "Logging", + "uid": "be3r0x46iwlq8f", + "version": 12, + "weekStart": "monday" +} diff --git a/package.json b/package.json index 3c237e6..4ecab31 100644 --- a/package.json +++ b/package.json @@ -6,6 +6,8 @@ "check:apps": "bunx biome check --write --config-path ./biome.json ./apps", "check:packages": "bunx biome check --write --config-path ./biome.json ./packages", "dev": "bun --filter '*' dev", + "dev:docker:up": "docker compose -f ci/development/docker-compose.yaml up -d", + "dev:docker:down": "docker compose -f ci/development/docker-compose.yaml down", "build": "bun --filter '*' build", "db:generate": "bun --filter '@boring.tools/database' db:generate", "db:migrate": "bun --filter '@boring.tools/database' db:migrate", @@ -26,10 +28,7 @@ "docker:page": "bun docker:page:build && bun docker:page:push" }, "packageManager": "bun@1.1.29", - "workspaces": [ - "apps/*", - "packages/*" - ], + "workspaces": ["apps/*", "packages/*"], "devDependencies": { "@biomejs/biome": "1.9.4", "lefthook": "^1.7.15"