A destroyed monitor on the sidewalk with a crushed soda can

Recovering from a Serious PC Crash

Join me as I share some interesting things I learned during my journey to rebuild my development environment.

Published

4 min read

Introduction

Recently, I suffered a catastrophic failure of my home computer. Running Windows 11 post an upgrade from Windows 10, I suspect the root of the issue was an inadvertent shutdown during the upgrade. This eventually led me to face the dreaded error: 0xc0000001. Research suggests that this error might have stemmed from file corruption due to the premature shutdown.

While I’d love to detail the diagnosis process, this article’s focus lies elsewhere. My system recovery attempts were unsuccessful, prompting me to get a new SSD and perform a fresh installation. The silver lining? Realizing the significance of early backup processes. Fortunately, my foresight minimized data loss.

With a brand new Windows 11, I embarked on the journey of reconstructing my local development environment.

Recreating My Development Environment

In my initial setup phase, I adhered to my tried-and-true method: creating an admin and a standard user account. This approach, honed over years of Windows usage, acts as a safety net, preventing inadvertent errors that require elevated permissions.

I’ll fast forward a bit. After setting up my standard environment, I ventured into reconstructing my Node development environment. Historically, I’ve relied on nvm-windows. For the uninitiated, nvm-windows, akin to nvm, is a version manager allowing seamless Node runtime switches. A handy tool when juggling projects with varying Node version dependencies.

Yet, this time around, my experience with nvm-windows was less than stellar. The need for elevated privileges for every nvm command was cumbersome. Coupled with scant documentation on running the node command post-installation, I decided to pivot. Enter Windows Sybsystem for Linux (WSL) and Ubuntu. My familiarity with nvm made this transition feel natural.

WSL and Ubuntu: Setup Chronicles

On paper, setting up WSL should be a breeze, especially with Microsoft’s comprehensive guide: How to install Linux on Windows with WSL. A simple wsl --install should suffice.

Reality, however, presented challenges. An obscure error message post-installation hinted at underlying issues. Delving deeper, I pinpointed the culprits: the Virtual Machine Platform and Windows Subsystem for Linux features were disabled. Here’s how you can activate them:

  1. Use the Windows start menu, searching for “Turn Windows features on or off”.
  2. Ensure the “Virtual Machine Platform” option is checked.
  3. Similarly, enable the “Windows Subsystem for Linux” option.

A system reboot might be necessary post this change. For me, post-reboot, wsl --install worked flawlessly, allowing me to finalize my Ubuntu setup.

Essential Development Tools on WSL

Installing NVM

The NVM installation is pretty simple. All one needs to do is use the install script and restart their terminal after the script runs. Check out the Installing and Updating section of the README for more details.

Installing Visual Studio Code and Extensions

For the actual integrated development environment (IDE), I like to use Visual Studio Code for my side projects these days. Getting it set up ended being extremely easy. The following extensions were suggested by the editor itself:

Wrapping Up

In the face of adversity, there lies an opportunity. My unexpected system collapse, while initially a daunting hurdle, metamorphosed into an enlightening journey through the intricacies of setting up a development environment on Windows. I found myself not only reconstructing what was lost but fortifying and optimizing my setup with newfound knowledge.

Several key takeaways punctuated this experience:

  1. Backup Early, Backup Often: The minimal data loss I encountered, despite a complete system meltdown, accentuated the importance of regular backups. A safety net I’d advise every developer to weave.
  2. Flexibility Over Frustration: When familiar tools faltered, like my experience with nvm-windows, the ability to pivot and adapt by turning to alternatives such as nvm within WSL was invaluable. Embracing change, rather than resisting it, proved to be a more efficient approach.
  3. Deep Dive Into Errors: Instead of skirting around error messages or seeing them as mere hindrances, treating them as guiding beacons helped. My endeavor with the WSL installation is a testament to how diving deep into errors can unravel their mysteries and pave the way for solutions.
  4. The Value of Comprehensive Tools: The seamless transition to Visual Studio Code and its vast array of extensions highlighted the significance of versatile tools that adapt to varied developmental needs.
  5. Continuous Learning: This entire episode underscored the fact that in the tech realm, learning is ceaseless. New challenges breed new solutions, and each stumbling block is but a stepping stone to greater understanding.

In retrospect, while I wouldn’t wish for another system failure, I appreciate the silver linings of this episode. Not only did I emerge with a more robust development environment, but I also fortified my troubleshooting arsenal, ready for future challenges.

Here’s to the unpredictable challenges of the tech world, and the myriad learning opportunities they cloak!


profile
Welcome to my blog! I am a software engineer based in Southern California, and I love sharing my thoughts and experiences about all things tech. From software development and programming to the latest tech trends and news, you'll find it all here on my blog. Follow along to stay up to date and get insights from a real-life software engineer living and working in SoCal. Thanks for visiting!
New post!

My 2025 Roadmap: Balancing Growth, Creativity, and Impact

Click here to read more!