Why Your Code is Hanging: Unraveling the “ScriptTimeout” Mystery

Salim Segaf Alqosam
3 min readFeb 11, 2025

--

Script Timeout

Alright, imagine this: You’re running some ⚡ C# web service methods, and suddenly — 💥 boom! Your app just 💤 hangs like an old-school 🖥️ Windows XP freeze. What happened? Let’s break it down. 🧐

🚨 The Problem: Long-Running Requests ⏳

Look at this chunk of code: 📜

[WebMethod]
public string TestWithTimeout600()
{
HttpContext.Current.Server.ScriptTimeout = 600;
try
{
System.Threading.Thread.Sleep(500000); // 🛌 Sleep for 500 sec
return "✅ Update berhasil 600!";
}
catch (Exception ex)
{
return "❌ Error: " + ex.Message;
}
}

And this one: 🤔

[WebMethod]
public string TestWithTimeout60()
{
try
{
System.Threading.Thread.Sleep(500000); // 💤 Sleep for 500 sec
return "✅ Update berhasil 60!";
}
catch (Exception ex)
{
return "❌ Error: " + ex.Message;
}
}

Both methods are trying to sleep for 500 seconds (⏰ an eternity in web request time). But notice something different? The first method explicitly sets ScriptTimeout = 600, while the second doesn’t. 🧐

🤔 What is ScriptTimeout Anyway?

HttpContext.Current.Server.ScriptTimeout controls how long the 🌐 server will allow a request to run before it ⏳ times out. By default, this value is often 90 seconds on most 🖥️ servers. So if you don’t change it, your second method will likely fail after 90 seconds, even though you expected it to run longer. 😬

The first method extends the timeout to 600 seconds (⏳ 10 minutes), meaning it won’t get killed off prematurely — at least in theory. But there’s a catch… 🎣

❌ Why This Code Still Sucks 😵‍💫

Even though ScriptTimeout = 600 sounds like a fix, long-running requests are 🚩 bad practice. Here’s why:

  1. 🛑 Hogging Resources — Keeping a 🧵 thread alive for so long blocks server resources, making your app 🐌 slow for other users.
  2. 🚫 Client Disconnection — Most 🖥️ browsers will disconnect after 2 minutes, making the extended timeout useless. 🤷‍♂️
  3. ⚠️ Scalability Nightmare — What if 100 users call this at the same time? 💀 RIP, server.

✅ The Proper Fix: Asynchronous Processing 🚀

Instead of making the client 🧑‍💻 wait for 500 seconds (which is ridiculous 🙄), you should:

  • 🔄 Offload the work to a background task
  • 📩 Return an immediate response with a status update URL 🔗
  • 🏃 Use asynchronous programming (e.g., async/await in .NET) ⚡

🏆 A Better Approach:

[WebMethod]
public async Task<string> TestAsyncProcessing()
{
Task.Run(() => LongRunningProcess()); // 🚀 Fire and forget
return "✅ Processing started, check back later!";
}
private void LongRunningProcess()
{
System.Threading.Thread.Sleep(500000);
// ✅ Do actual processing here
}

Now, your API responds instantly while handling the work in the background. Much better, right? 😉

🔥 TL;DR 🔥

  • ScriptTimeout lets you extend ⏳ request timeouts, but it's not a great solution. ❌
  • Long-running web requests block resources 🖥️ and hurt scalability. 🚨
  • Instead, use asynchronous processing 🏃 or background jobs. ✅

Don’t let your server 🖥️ die a slow death. Be smart, go async! 🚀🔥

Sign up to discover human stories that deepen your understanding of the world.

--

--

Salim Segaf Alqosam
Salim Segaf Alqosam

Written by Salim Segaf Alqosam

Fullstack Developer | .NET | React.js | React Native

No responses yet

Write a response