<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Mayank Saini</title>
    <description>The latest articles on Forem by Mayank Saini (@mayank_saini).</description>
    <link>https://forem.com/mayank_saini</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3854763%2F66bf67de-44fc-4c99-849d-53926a799e79.jpg</url>
      <title>Forem: Mayank Saini</title>
      <link>https://forem.com/mayank_saini</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/mayank_saini"/>
    <language>en</language>
    <item>
      <title>How I Improved My Express API Performance (and Built a Toolkit for It)</title>
      <dc:creator>Mayank Saini</dc:creator>
      <pubDate>Wed, 01 Apr 2026 05:26:27 +0000</pubDate>
      <link>https://forem.com/mayank_saini/how-i-improved-my-express-api-performance-and-built-a-toolkit-for-it-2894</link>
      <guid>https://forem.com/mayank_saini/how-i-improved-my-express-api-performance-and-built-a-toolkit-for-it-2894</guid>
      <description>&lt;p&gt;When working on production APIs, performance is something you &lt;em&gt;feel&lt;/em&gt; before you fully understand.&lt;/p&gt;

&lt;p&gt;Slow responses.&lt;br&gt;
Unclear bottlenecks.&lt;br&gt;
No visibility into what's actually happening.&lt;/p&gt;

&lt;p&gt;I ran into the same problem while working on an Express.js backend — and that’s what led me to build an open-source solution.&lt;/p&gt;


&lt;h2&gt;
  
  
  ⚠️ The Problem
&lt;/h2&gt;

&lt;p&gt;In a typical Express app, debugging performance isn’t straightforward.&lt;/p&gt;

&lt;p&gt;You might ask:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Which API is slow?&lt;/li&gt;
&lt;li&gt;Is it database time or middleware overhead?&lt;/li&gt;
&lt;li&gt;How many requests are hitting my server?&lt;/li&gt;
&lt;li&gt;Where is latency coming from?&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The issue is:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Express doesn’t give you this visibility out of the box.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;So we end up:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Adding random &lt;code&gt;console.log&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;Writing custom timers&lt;/li&gt;
&lt;li&gt;Or guessing based on intuition&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;None of these scales.&lt;/p&gt;


&lt;h2&gt;
  
  
  💡 The Idea
&lt;/h2&gt;

&lt;p&gt;I wanted something simple:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;A plug-and-play tool that shows real-time performance insights for Express apps.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;No heavy setup.&lt;br&gt;
No external services.&lt;br&gt;
Just install → use → understand.&lt;/p&gt;


&lt;h2&gt;
  
  
  🛠️ What I Built
&lt;/h2&gt;

&lt;p&gt;I created an open-source package:&lt;/p&gt;

&lt;p&gt;👉 &lt;strong&gt;Express Performance Toolkit&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;It helps you:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Track API response times&lt;/li&gt;
&lt;li&gt;Monitor request counts&lt;/li&gt;
&lt;li&gt;Identify slow endpoints&lt;/li&gt;
&lt;li&gt;Visualize performance via a dashboard&lt;/li&gt;
&lt;li&gt;Webhook support&lt;/li&gt;
&lt;/ul&gt;


&lt;h2&gt;
  
  
  ⚡ Quick Setup
&lt;/h2&gt;

&lt;p&gt;Getting started takes less than a minute:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install &lt;/span&gt;express-performance-toolkit
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;





&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="nx"&gt;express&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;express&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="nx"&gt;performanceToolkit&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;express-performance-toolkit&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;app&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;express&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;

&lt;span class="nx"&gt;app&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;use&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nf"&gt;performanceToolkit&lt;/span&gt;&lt;span class="p"&gt;().&lt;/span&gt;&lt;span class="nx"&gt;middleware&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="nx"&gt;app&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;get&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;/&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;req&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;res&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;res&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;send&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Hello World&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;

&lt;span class="nx"&gt;app&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;listen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;3000&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;That’s it.&lt;/p&gt;




&lt;h2&gt;
  
  
  📊 What You Get
&lt;/h2&gt;

&lt;h3&gt;
  
  
  1. API Performance Tracking
&lt;/h3&gt;

&lt;p&gt;You can see:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Response time per route&lt;/li&gt;
&lt;li&gt;Average latency&lt;/li&gt;
&lt;li&gt;Request frequency&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  2. Real-Time Insights
&lt;/h3&gt;

&lt;p&gt;Instead of guessing, you now know:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Which route is slow&lt;/li&gt;
&lt;li&gt;How your app behaves under load&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  3. Built-in Dashboard
&lt;/h3&gt;

&lt;p&gt;A simple UI to visualise:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Requests&lt;/li&gt;
&lt;li&gt;Performance trends&lt;/li&gt;
&lt;li&gt;Endpoint-level metrics&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  🔥 Real Impact
&lt;/h2&gt;

&lt;p&gt;After using this internally, I noticed:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Faster debugging of performance issues&lt;/li&gt;
&lt;li&gt;Better understanding of API behavior&lt;/li&gt;
&lt;li&gt;Reduced time spent on manual logging&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Instead of reacting late, I could &lt;strong&gt;see issues early&lt;/strong&gt;.&lt;/p&gt;




&lt;h2&gt;
  
  
  🧠 Key Learning
&lt;/h2&gt;

&lt;p&gt;The biggest lesson wasn’t just about performance.&lt;/p&gt;

&lt;p&gt;It was this:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Visibility is more important than optimisation.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;You can’t fix what you can’t see.&lt;/p&gt;




&lt;h2&gt;
  
  
  🚀 Why I Open-Sourced It
&lt;/h2&gt;

&lt;p&gt;I realised many developers face the same problem:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Early-stage apps lack monitoring&lt;/li&gt;
&lt;li&gt;Full tools like Datadog or New Relic feel heavy&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;So I built something:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Lightweight&lt;/li&gt;
&lt;li&gt;Developer-friendly&lt;/li&gt;
&lt;li&gt;Easy to integrate&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  📦 Try It Out
&lt;/h2&gt;

&lt;p&gt;If you work with Express.js, give it a try:&lt;/p&gt;

&lt;p&gt;👉 &lt;a href="https://www.npmjs.com/package/express-performance-toolkit" rel="noopener noreferrer"&gt;https://www.npmjs.com/package/express-performance-toolkit&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;👉 &lt;a href="https://github.com/Sainimayank1/express-performance-toolkit" rel="noopener noreferrer"&gt;https://github.com/Sainimayank1/express-performance-toolkit&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;👉 &lt;a href="https://express-performance-toolkit.netlify.app/" rel="noopener noreferrer"&gt;https://express-performance-toolkit.netlify.app/&lt;/a&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  🙌 Feedback
&lt;/h2&gt;

&lt;p&gt;I’m actively improving this package.&lt;/p&gt;

&lt;p&gt;If you:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Try it out&lt;/li&gt;
&lt;li&gt;Have suggestions&lt;/li&gt;
&lt;li&gt;Want new features&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Feel free to open an issue or contribute.&lt;/p&gt;




&lt;h2&gt;
  
  
  🧩 What’s Next
&lt;/h2&gt;

&lt;p&gt;I’m currently working on:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;More advanced metrics&lt;/li&gt;
&lt;li&gt;Better dashboard visualisation&lt;/li&gt;
&lt;li&gt;Production-ready features&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  ✨ Final Thought
&lt;/h2&gt;

&lt;p&gt;Performance is not just about speed.&lt;/p&gt;

&lt;p&gt;It’s about &lt;strong&gt;understanding your system&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;And sometimes, a small tool can make a big difference.&lt;/p&gt;




&lt;p&gt;If this helped you, feel free to share your thoughts 👇&lt;/p&gt;

</description>
      <category>api</category>
      <category>node</category>
      <category>performance</category>
      <category>showdev</category>
    </item>
  </channel>
</rss>
