tests/fixtures/logs/app-json.log

{"ts":"2025-04-18T10:00:00Z","lvl":"info","svc":"api","msg":"listening","port":8080}
{"ts":"2025-04-18T10:00:01Z","lvl":"info","svc":"api","req_id":"r-1","route":"/v1/users","status":200,"dur_ms":12}
{"ts":"2025-04-18T10:00:02Z","lvl":"info","svc":"api","req_id":"r-2","route":"/v1/orders","status":200,"dur_ms":47}
{"ts":"2025-04-18T10:00:03Z","lvl":"warn","svc":"api","req_id":"r-3","route":"/v1/login","status":401,"dur_ms":22,"reason":"bad_password"}
{"ts":"2025-04-18T10:00:04Z","lvl":"info","svc":"api","req_id":"r-4","route":"/v1/login","status":200,"dur_ms":31}
{"ts":"2025-04-18T10:00:05Z","lvl":"info","svc":"api","req_id":"r-5","route":"/v1/orders","status":200,"dur_ms":22}
{"ts":"2025-04-18T10:00:06Z","lvl":"error","svc":"api","req_id":"r-6","route":"/v1/webhooks/stripe","status":500,"dur_ms":1211,"err":"database timeout"}
{"ts":"2025-04-18T10:00:07Z","lvl":"error","svc":"api","req_id":"r-6","route":"/v1/webhooks/stripe","status":500,"dur_ms":301,"err":"database timeout"}
{"ts":"2025-04-18T10:00:08Z","lvl":"warn","svc":"api","req_id":"r-7","route":"/v1/webhooks/stripe","status":503,"dur_ms":501,"err":"retry-later"}
{"ts":"2025-04-18T10:00:09Z","lvl":"info","svc":"api","req_id":"r-8","route":"/v1/webhooks/stripe","status":200,"dur_ms":42}
{"ts":"2025-04-18T10:00:10Z","lvl":"info","svc":"worker","tag":"queue-consume","topic":"orders","count":42}
{"ts":"2025-04-18T10:00:11Z","lvl":"info","svc":"worker","tag":"queue-consume","topic":"orders","count":41}
{"ts":"2025-04-18T10:00:12Z","lvl":"error","svc":"worker","tag":"queue-consume","topic":"shipments","err":"kafka: connection refused"}
{"ts":"2025-04-18T10:00:13Z","lvl":"warn","svc":"worker","tag":"queue-consume","topic":"shipments","lag_s":27}
{"ts":"2025-04-18T10:00:14Z","lvl":"info","svc":"worker","tag":"queue-consume","topic":"shipments","count":19}
{"ts":"2025-04-18T10:00:15Z","lvl":"info","svc":"api","req_id":"r-9","route":"/v1/orders/10015","status":422,"dur_ms":11,"reason":"validation_failed"}
{"ts":"2025-04-18T10:00:16Z","lvl":"info","svc":"api","req_id":"r-10","route":"/v1/orders/10015","status":200,"dur_ms":19}
{"ts":"2025-04-18T10:00:17Z","lvl":"info","svc":"api","req_id":"r-11","route":"/v1/metrics","status":200,"dur_ms":4}
{"ts":"2025-04-18T10:00:18Z","lvl":"info","svc":"api","req_id":"r-12","route":"/v1/metrics","status":200,"dur_ms":4}
{"ts":"2025-04-18T10:00:19Z","lvl":"error","svc":"api","req_id":"r-13","route":"/v1/reports/weekly","status":504,"dur_ms":30001,"err":"gateway-timeout"}
{"ts":"2025-04-18T10:00:20Z","lvl":"info","svc":"api","req_id":"r-14","route":"/v1/reports/weekly","status":200,"dur_ms":22111}
{"ts":"2025-04-18T10:00:21Z","lvl":"info","svc":"api","req_id":"r-15","route":"/v1/audit/2025-04-17","status":200,"dur_ms":8102}
{"ts":"2025-04-18T10:00:22Z","lvl":"info","svc":"api","req_id":"r-16","route":"/v1/audit/2025-04-16","status":200,"dur_ms":8011}
{"ts":"2025-04-18T10:00:23Z","lvl":"info","svc":"api","req_id":"r-17","route":"/v1/audit/2025-04-15","status":200,"dur_ms":7902}
{"ts":"2025-04-18T10:00:24Z","lvl":"warn","svc":"api","req_id":"r-18","route":"/v1/invoices/991","status":403,"dur_ms":3,"reason":"missing_role"}
{"ts":"2025-04-18T10:00:25Z","lvl":"info","svc":"api","req_id":"r-19","route":"/v1/invoices/992","status":200,"dur_ms":17}
{"ts":"2025-04-18T10:00:26Z","lvl":"info","svc":"api","req_id":"r-20","route":"/v1/invoices/993","status":200,"dur_ms":18}
{"ts":"2025-04-18T10:00:27Z","lvl":"info","svc":"worker","tag":"retry","topic":"shipments","attempt":2,"count":5}
{"ts":"2025-04-18T10:00:28Z","lvl":"info","svc":"worker","tag":"retry","topic":"shipments","attempt":3,"count":0}
{"ts":"2025-04-18T10:00:29Z","lvl":"info","svc":"worker","tag":"shutdown","reason":"signal","signal":"SIGTERM"}