惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

SecWiki News
SecWiki News
M
MIT News - Artificial intelligence
博客园 - 司徒正美
I
InfoQ
V
V2EX
L
LangChain Blog
人人都是产品经理
人人都是产品经理
T
Tailwind CSS Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
The GitHub Blog
The GitHub Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
WordPress大学
WordPress大学
H
Help Net Security
美团技术团队
Y
Y Combinator Blog
G
Google Developers Blog
小众软件
小众软件
The Cloudflare Blog
博客园 - 三生石上(FineUI控件)
Jina AI
Jina AI
量子位
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Spread Privacy
Spread Privacy
博客园 - 聂微东
The Register - Security
The Register - Security
F
Full Disclosure
S
Securelist
G
GRAHAM CLULEY
Cyberwarzone
Cyberwarzone
F
Fox-IT International blog
H
Hacker News: Front Page
C
Cisco Blogs
D
Docker
L
LINUX DO - 热门话题
Google Online Security Blog
Google Online Security Blog
T
Troy Hunt's Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
T
ThreatConnect
aimingoo的专栏
aimingoo的专栏
Last Week in AI
Last Week in AI
J
Java Code Geeks
宝玉的分享
宝玉的分享
Project Zero
Project Zero
L
LINUX DO - 最新话题
博客园_首页
MongoDB | Blog
MongoDB | Blog
Stack Overflow Blog
Stack Overflow Blog
P
Proofpoint News Feed
博客园 - 叶小钗

DEV Community

Great example of Gemma 4 moving beyond chatbots into real-world decision support. Using AI to guide everyday actions like recycling shows how impactful applied LLMs can be when designed for usability, not just capability. #Gemma4 #AI #Sustainability Building a Production AI Chatbot for an Educational Institute: Architecture, Lessons & Full Stack Deep-Dive Google Login in Express with PassportJS & JWT How I reclaimed 47GB on my MacBook by cleaning developer project junk Operators Are Not Oracles: How We Learned to Stop Worrying and Love the Configuration I Built 6 Free Developer Tools for AI APIs, Cron, Docker, and Self-Hosting How I Built a Real-Time Precious Metals Price Feed for 30,000 Concurrent Users in Laravel How to Use a SERP API to Validate Whether a Project Idea Is Worth Building Gemma 4 discussions often focus on capability, but real-world impact depends on deployment context. For offline education, especially in low-connectivity regions, latency, cost, and local inference matter as much as model strength. Local Mind Explores it Space Complexity + Ω and Θ Notations Google I/O 2026 Just Confirmed the Shift From AI Chatbots to AI Agents Designing an In-Game Inflation Tracking Algorithm for Web Utility Apps Google AI Studio Just Changed the Shape of App Development If you struggle to learn then this is for you. Best AI Agent Security & Guardrails Tools in 2026: LLM Guard vs NeMo vs Guardrails AI Building Dynamic RBAC in React 19: From Permission Strings to Component-Level Access Control How to Build a Self-Hosted AI Code Review Tool in Python Why We Switched from React to HTMX in Production: A 200-Site Case Study Gemma-Loom: The Intent-Based Virtual Machine (IVM) for Edge Sovereignty Java实习海投攻略:3天300个沟通,我是怎么拿到面试的 I Deployed Netflix's Web Server in 30 Seconds (And So Can You) - Docker Project 1 Debugging Android 14 WebRTC Disconnects on a coturn Relay Path 1/30 Days System Design Question Testing FastAPI + SQLAlchemy with Real PostgreSQL Fixtures: No More Mocking Misery FAQ Schema Markup Generators: What They Actually Do (and What They Don't Tell You) How a pure-TypeScript flex layout engine closed the last WASM-Yoga gap Spot instances as GitHub Actions runners Agents Need Receipts, Not Just Better Prompts readmegen — Generate beautiful README.md in seconds (12 templates, open source) When AI Reads Blueprints: The Hidden Attack Surface of Multimodal Engineering Intelligence Simplicity scales — complexity kills side projects AI does exactly what you ask — that's the problem How a model upgrade silently broke our extraction prompt (and how we caught it) The Best Form Backend for Static Sites in 2026 # ⛽ I Built a Cross-Platform Fuel Finder with React & Supabase: The Indie Dev Journey The 11 Major Cloud Service Providers in 2025 Membangun Karya Visual: Mengintip Fasilitas Multimedia dan Studio Kreatif Amikom What Is IOPS? Visualizing Database Design: From Interactive Canvas to Drizzle, Prisma, and SQL in Real-time A tool to make your GitHub README impossible to ignore 🚀 Zero-Downtime Blue-Green and IP-Based Canary Deployments on ECS Fargate I reproduced a Claude Code RCE. The bug pattern is everywhere. We Replaced Our RAG Pipeline With Persistent KV Cache. Here's What We Found. Jenkins CI/CD Pipeline for a Dockerized Node.js Application: Manual Trigger vs Automatic Trigger Using GitHub Webhooks How to Stream Live Forex Rates to Google Sheets API: A Complete Guide Small Models Will Beat Giant Models (And Most People Haven’t Realized Why Yet) How I Built 5 Linux Automation Scripts on AWS EC2 I built TokenPatch to measure AI coding cost per applied patch I built a Chrome extension to stop squinting at the web Producer audit clean, six tests red Conversa — A Multi-Agent AI Platform Powered by Gemma 4 Build a Real Agent in 15 Minutes with Gemini's New Managed Agents API What I Actually Build: AI Systems That Ship, Not Demos That Impress The Box Ticked While You Read This: LinkedIn, AI Training, and the Switch You Did Not Flip Investasi Masa Depan: Mengintip Fasilitas Laboratorium Komputer Kelas Dunia di Yogyakarta I Cancelled My $20 Claude Cowork Plan After a Week With OpenWork Stop Reviewing Every Line of AI Code - Build the Trust Stack Instead How To Build an Image Cropper in Browser (Simple Steps) I built a macOS disk cleaner for developers and just launched it would love feedback Membangun Kompetensi dan Relasi: Mengapa Ekosistem Kampus Itu Penting I Built an AI That Decides Which AI to Talk To — Running 24/7 From My Living Room Codex Team Usage SOP How to Actually Become a Programmer: The Hard Part Nobody Wants to Explain Building a Production-Style Multi-Tool AI Agent with Python, Flask, React & Gemini AI The Caretaker Sandbox: An Offline-First Visual Playground & Template Engine powered by Gemma 4 # Building Instagram OSINT Projects with HikerAPI Your AI can read. Gemma 4 can see The Battle of the Senior Dev: Why AI Gives You Wings But Only If You're Ready to Pilot HiDream Raw Output Failed Tried Dev-2604 VRAM Math Killed It Won with a Prompt Enhancer Instead I Finally Finished a Project I Abandoned — And GitHub Copilot Helped Me Ship It SafeSMS: On-Device Threat Detection with Gemma 4 E4B, no internet required I Built OpenKap — A Loom Alternative for Small Teams Who Just Want to Ship Gemma 4 is Here: The Dawn of Local Multimodal Reasoning Offline-First Flutter: How We Built a CRM That Manages 100K+ Leads With No Internet Memory for Agents: When Vectors Meet Graphs, Bugs Drop 4 The Rise of Production-Grade AI Infrastructure I ran my idea-validation product through its own validator. The verdict was PIVOT. We Built an Agent Commerce API. Google I/O 2026 Changed Our 3-Month Roadmap in 24 Hours. "My Partner's Memory Was Full. I Didn't Know — Until We Tried to Talk." I’m a Front End Web Developer Learning Machine Learning From Scratch Laravel Waiting Request I Built a Chrome Extension to Track How Long You Actually Spend on Each Tab Why Google Can't See Your React Breadcrumbs (And the 4-Line Fix) AI Travel Assistant Powered by Gemma 4; With Streaming, Image Input, and Visual Recommendation Cards Microsoft tried to kill the printer driver. Healthcare said no. The Blueprint Beneath the Blueprint: Designing Data Model and Choosing Its Database REST APIs vs Webhooks in Telecom Billing - Which One Actually Makes Sense? Accounting Made Simple: AI-Powered Financial Insights of Japanese Companies with Gemma 4 The append-only AST trick that makes Flutter AI chat actually smooth Designing the Future of Payments — Why XML Still Matters in the Age of APIs From Legacy to Live — Reviving XMLPayments with GitHub Copilot Two Weeks Into Learning Solana XMLPayments — The Hidden Backbone of Modern Financial Orchestration AI Agents in Practice — Read from the beginning Reviving My Gemma Agentic Framework: From Prototype to Polished Repo Smart Contracts Demand Better Infrastructure: Building on contract.dev Self-Hosted LLM Tool Calling: Forge and the Build-vs-Buy Decision ORA-00072 오류 원인과 해결 방법 완벽 가이드 OpenWA for CTOs: Self-Hosted WhatsApp Gateway Trade-Offs NotebookLM Automation With notebooklm-py: Useful, But Classify Data First
How to Add API Monitoring to an Express App in 5 Minutes (2026)
Ayo · 2026-05-23 · via DEV Community

Ayo

Step 2: Install the SDK

One command:

npm install pingoni

Enter fullscreen mode Exit fullscreen mode

That's the entire install. No native dependencies, no agent to configure, no separate config file.

Step 3: Add the middleware

Two lines change in your app.js. Require the package at the top, then mount the middleware before your routes:

const express = require("express");
const pingoni = require("pingoni");
const app = express();

app.use(express.json());
app.use(pingoni(process.env.PINGONI_API_KEY));   // ← add this

app.get("/", (req, res) => {
  res.json({ status: "ok" });
});

// ... rest of your routes

Enter fullscreen mode Exit fullscreen mode

That's it. Every request to your app will now be captured: method, path, status code, response time, timestamp. Mounting the middleware before your routes means it wraps everything — including the static and JSON parsing middleware.

Step 4: Add the error handler

Errors need a separate handler because of how Express's error-handling pipeline works. Express error middleware must be the last middleware mounted — after all your routes.

// ... all your routes go here ...

app.use(pingoni.errorHandler(process.env.PINGONI_API_KEY));  // ← add at the bottom
app.listen(PORT, () => console.log(`Listening on ${PORT}`));

Enter fullscreen mode Exit fullscreen mode

This catches any error that bubbles up from your routes — including uncaught exceptions, errors passed to next(err), and async errors in handlers that use modern Express patterns. Stack traces, the request that caused the error, and the error message are all captured automatically.

The complete instrumented app

Here's what your app looks like fully instrumented. Two added lines total:

const express = require("express");
const pingoni = require("pingoni");
const app = express();

app.use(express.json());
app.use(pingoni(process.env.PINGONI_API_KEY));

app.get("/", (req, res) => {
  res.json({ status: "ok" });
});

app.get("/users/:id", (req, res) => {
  res.json({ id: req.params.id, name: "Sample User" });
});

app.post("/orders", (req, res) => {
  res.status(201).json({ orderId: "ord_abc123" });
});

app.use(pingoni.errorHandler(process.env.PINGONI_API_KEY));

const PORT = process.env.PORT || 3000;
app.listen(PORT, () => console.log(`Listening on ${PORT}`));

Enter fullscreen mode Exit fullscreen mode

Five minutes of work. Production-ready monitoring.

Step 5: Test it locally

Start the app and hit a few endpoints:

node app.js

# In another terminal:
curl http://localhost:3000/
curl http://localhost:3000/users/42
curl -X POST http://localhost:3000/orders -H "Content-Type: application/json" -d '{}'

Enter fullscreen mode Exit fullscreen mode

Open your Pingoni dashboard within 30 seconds and you should see the requests appearing — method, path, status code, response time. To confirm the error handler works, add a route that throws:

app.get("/break", (req, res) => {
  throw new Error("intentional test error");
});

Enter fullscreen mode Exit fullscreen mode

Hit it once, then check your dashboard — the error should show up with the full stack trace and the request that triggered it.

Step 6: Deploy

If you're already deployed to Railway, Vercel, Render, Fly, or anywhere else: add PINGONI_API_KEY to your environment variables in that platform's settings, redeploy, and you're done.

If you haven't deployed yet, this is exactly the right time. Monitoring on day one of production beats monitoring set up after the first incident.

What you actually see in the dashboard

Once events are flowing, the dashboard gives you:

  • Live request feed: most recent requests with their timing and status
  • Endpoint breakdown: requests per endpoint, broken down by status code (so you can see "POST /orders is throwing 5% errors")
  • Latency per endpoint: p50, p95, p99 for each route
  • Error feed: every exception with stack trace, the URL that caused it, and request metadata
  • Traffic over time: request volume so you can see traffic patterns

You're now in the small minority of small-team Express apps that actually have production visibility.

Going further

The setup above gives you the essentials. A few things worth knowing for later:

Custom tags. You can attach metadata to a request (user ID, feature flag, A/B variant) for filtering in the dashboard. This becomes useful once you have meaningful traffic and want to slice by dimension.

Email alerts. Pingoni sends email alerts on high error rates. Configure thresholds in your dashboard settings. Webhook delivery (Slack, PagerDuty, etc.) is on the near-term roadmap.

Frontend monitoring. This post is about API monitoring. If you also want to capture frontend errors (JS exceptions in the browser, slow page loads, etc.), pair this with a frontend tool like Sentry. The two solve different problems.

Honest alternatives

In the interest of giving you the full picture: Pingoni isn't the only option for monitoring an Express app. A few others worth knowing about:

  • Sentry — best in class for error monitoring specifically, less focused on request/latency tracking. Pair well together.
  • New Relic — full APM with a generous free tier (100GB/month). More setup, but more features if you're growing.
  • Better Stack — strong for uptime monitoring + log management with a clean UI.
  • Self-hosted SigNoz — open source, OpenTelemetry-based. More work to operate, no vendor lock-in.

Pick the one that matches your stack and team size. The worst monitoring stack is the one you keep meaning to set up but haven't.

Wrapping up

Adding monitoring to an Express app shouldn't be a project. Two lines of code, one npm install, one environment variable. If you're shipping Node APIs in 2026 without basic request and error tracking, you're flying blind for no good reason — the tools have caught up to small teams.

If you want to try Pingoni specifically, the free tier covers 10,000 requests/month and the setup is exactly what's in this post. If something else on the list fits better, use that. Just ship something.