<?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>DEV Community: Hardik Agarwal</title>
    <description>The latest articles on DEV Community by Hardik Agarwal (@hardik-agarwal18).</description>
    <link>https://dev.to/hardik-agarwal18</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%2F3846562%2F917d98cf-fac7-4464-9d54-2fe5ef49efdb.jpeg</url>
      <title>DEV Community: Hardik Agarwal</title>
      <link>https://dev.to/hardik-agarwal18</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/hardik-agarwal18"/>
    <language>en</language>
    <item>
      <title>npm run dev vs npm start: The Difference That Breaks Your App in Production</title>
      <dc:creator>Hardik Agarwal</dc:creator>
      <pubDate>Mon, 30 Mar 2026 18:12:07 +0000</pubDate>
      <link>https://dev.to/hardik-agarwal18/npm-run-dev-vs-npm-start-the-difference-that-breaks-your-app-in-production-1372</link>
      <guid>https://dev.to/hardik-agarwal18/npm-run-dev-vs-npm-start-the-difference-that-breaks-your-app-in-production-1372</guid>
      <description>&lt;p&gt;Everything was working perfectly.&lt;/p&gt;

&lt;p&gt;I ran:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm run dev
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;And my app felt amazing.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;It reloaded instantly&lt;/li&gt;
&lt;li&gt;It never stayed broken&lt;/li&gt;
&lt;li&gt;Errors? Fixed themselves after save&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Honestly, it felt like I had built something solid.&lt;/p&gt;

&lt;p&gt;Then I deployed it.&lt;/p&gt;

&lt;p&gt;And everything fell apart.&lt;/p&gt;




&lt;h2&gt;
  
  
  What Went Wrong?
&lt;/h2&gt;

&lt;p&gt;The app started crashing.&lt;/p&gt;

&lt;p&gt;Sometimes it just stopped responding.&lt;br&gt;
Sometimes logs didn’t show anything useful.&lt;br&gt;
And the worst part?&lt;/p&gt;

&lt;p&gt;It didn’t recover on its own.&lt;/p&gt;

&lt;p&gt;I kept thinking:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“But it was working perfectly on my machine…”&lt;/p&gt;
&lt;/blockquote&gt;


&lt;h2&gt;
  
  
  The Tiny Difference That Caused All This
&lt;/h2&gt;

&lt;p&gt;It came down to one small change:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="nl"&gt;"dev"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"nodemon index.js"&lt;/span&gt;&lt;span class="err"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="nl"&gt;"start"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"node index.js"&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



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

&lt;p&gt;Just:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;nodemon&lt;/code&gt; in development&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;node&lt;/code&gt; in production&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;At first, this looks harmless.&lt;/p&gt;

&lt;p&gt;But it changes &lt;strong&gt;everything&lt;/strong&gt;.&lt;/p&gt;




&lt;h2&gt;
  
  
  What nodemon Actually Does (And Why It Tricks You)
&lt;/h2&gt;

&lt;p&gt;When you use &lt;code&gt;nodemon&lt;/code&gt;, your app behaves very differently:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;It watches your files&lt;/li&gt;
&lt;li&gt;It restarts automatically on every change&lt;/li&gt;
&lt;li&gt;It even restarts after crashes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;So in development, your app feels… &lt;strong&gt;immortal&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;You break something? Save → fixed.&lt;br&gt;
Server crashes? It comes back instantly.&lt;/p&gt;

&lt;p&gt;You never really see failure.&lt;/p&gt;


&lt;h2&gt;
  
  
  But Production Is Not That Forgiving
&lt;/h2&gt;

&lt;p&gt;When you run:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;node index.js
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Things are very different.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No auto restart&lt;/li&gt;
&lt;li&gt;No file watching&lt;/li&gt;
&lt;li&gt;No safety net&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;If your app crashes…&lt;/p&gt;

&lt;p&gt;👉 it stays down.&lt;/p&gt;

&lt;p&gt;No warning. No recovery. Just silence.&lt;/p&gt;




&lt;h2&gt;
  
  
  The Mistake Most Developers Make
&lt;/h2&gt;

&lt;p&gt;We get used to this loop:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Code → Save → Auto restart → Everything works&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;And we assume:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“Yeah, this app is stable.”&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;But the truth is:&lt;/p&gt;

&lt;p&gt;👉 &lt;strong&gt;nodemon was hiding your problems&lt;/strong&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  Real Issues That Only Show Up in Production
&lt;/h2&gt;

&lt;h3&gt;
  
  
  1. Crashes are permanent
&lt;/h3&gt;

&lt;p&gt;In dev:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Crash → nodemon restarts → you move on&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;In prod:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Crash → your server is dead&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h3&gt;
  
  
  2. You don’t have a process manager
&lt;/h3&gt;

&lt;p&gt;Running this in production:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;node index.js
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;is risky.&lt;/p&gt;

&lt;p&gt;If it crashes, nobody brings it back.&lt;/p&gt;

&lt;p&gt;That’s why real systems use tools like PM2.&lt;/p&gt;

&lt;p&gt;They:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Restart your app automatically&lt;/li&gt;
&lt;li&gt;Keep logs&lt;/li&gt;
&lt;li&gt;Handle multiple instances&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  3. Your environment is different (and you forgot)
&lt;/h3&gt;

&lt;p&gt;In development, everything is relaxed.&lt;/p&gt;

&lt;p&gt;In production, you should be running:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="nv"&gt;NODE_ENV&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;production node index.js
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;But many people forget this.&lt;/p&gt;

&lt;p&gt;And suddenly:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Debug logs flood your system&lt;/li&gt;
&lt;li&gt;Performance drops&lt;/li&gt;
&lt;li&gt;Sensitive info might leak&lt;/li&gt;
&lt;/ul&gt;




&lt;h3&gt;
  
  
  4. Logging suddenly becomes useless
&lt;/h3&gt;

&lt;p&gt;In dev:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;works great&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;In prod:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Logs are messy or missing&lt;/li&gt;
&lt;li&gt;Debugging becomes painful&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;You realize:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“console.log is not a logging strategy.”&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h3&gt;
  
  
  5. You never tested real conditions
&lt;/h3&gt;

&lt;p&gt;Your app worked with:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;1 user&lt;/li&gt;
&lt;li&gt;0 pressure&lt;/li&gt;
&lt;li&gt;perfect conditions&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;But production?&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;100+ users&lt;/li&gt;
&lt;li&gt;concurrent requests&lt;/li&gt;
&lt;li&gt;unpredictable failures&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Tools like Autocannon exist for a reason.&lt;/p&gt;

&lt;p&gt;Because real systems behave very differently under load.&lt;/p&gt;




&lt;h2&gt;
  
  
  The Real Lesson
&lt;/h2&gt;

&lt;p&gt;The problem is not &lt;code&gt;nodemon&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;The problem is this assumption:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“If it works in development, it will work in production.”&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That’s not true.&lt;/p&gt;




&lt;h2&gt;
  
  
  What You Should Actually Do
&lt;/h2&gt;

&lt;p&gt;Here’s a better setup:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="nl"&gt;"scripts"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"dev"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"nodemon index.js"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"start"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"node index.js"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"prod"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"pm2 start index.js"&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;And more importantly:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Use &lt;code&gt;nodemon&lt;/code&gt; only for development&lt;/li&gt;
&lt;li&gt;Always test using &lt;code&gt;node&lt;/code&gt; before deploying&lt;/li&gt;
&lt;li&gt;Use a process manager in production&lt;/li&gt;
&lt;li&gt;Set &lt;code&gt;NODE_ENV=production&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;Don’t rely on auto-restarts&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  One Line That Changed My Thinking
&lt;/h2&gt;

&lt;p&gt;After going through all this, I realized:&lt;/p&gt;

&lt;p&gt;👉 &lt;code&gt;npm run dev&lt;/code&gt; helps you build fast&lt;br&gt;
👉 &lt;code&gt;npm start&lt;/code&gt; decides if your app survives&lt;/p&gt;




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

&lt;p&gt;Development is comfortable.&lt;/p&gt;

&lt;p&gt;It fixes your mistakes.&lt;br&gt;
It hides your crashes.&lt;br&gt;
It makes everything feel smooth.&lt;/p&gt;

&lt;p&gt;Production does the opposite.&lt;/p&gt;

&lt;p&gt;It exposes everything.&lt;/p&gt;

&lt;p&gt;So next time your app works perfectly on your machine…&lt;/p&gt;

&lt;p&gt;Pause for a second and ask:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“Would this still work… without nodemon watching my back?”&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That question alone can save you hours of debugging.&lt;/p&gt;

&lt;p&gt;—and maybe even your production system.&lt;/p&gt;

</description>
      <category>node</category>
      <category>npm</category>
      <category>nodemon</category>
    </item>
  </channel>
</rss>
