5 Things Ryan Dahl Regrets About Node.js

5 Things Ryan Dahl Regrets About Node.js

Daily short news for you
  • Deep Research - a web browsing tool for research that produces a summary in just a few minutes - compared to many hours of work for humans, according to their announcement.

    This feature is currently only available for Pro users. Although it has not been tested yet, many articles emphasize the impressive capabilities of this new tool. If you're still unsure what Deep Research can do, just imagine this: Tell it "I need research information on global coffee consumption from last year." That's it! Just sit back and wait a moment for it to search and compile the results, sending you a detailed report. Wow, that's pretty amazing!

    Immediately, huggingface published an article attempting to recreate this tool in their own way. Details at Open-source DeepResearch – Freeing our search agents. And it's no surprise that both have the flavor of AI Agents.

    » Read more
  • Living long enough in the Internet world, you can see that people here are quite eager to follow trends, and they spread rapidly at a dizzying pace.

    Just a few months ago, we were still astonished by the intelligence of large language models (LLMs) that could answer just like humans, and shortly after, they were updated with incredible thinking and reasoning capabilities. They are widely applied not only in programming fields. Recently, the term AI Agents has been creating a stir.

    So, what are AI Agents? In this short article, it is, of course, impossible to provide a brief yet comprehensive definition. Readers can refer to this very detailed article here Agents | Chip Huyen. To make it easier to visualize, AI Agents can be thought of as a person or some entity. The Agents themselves are equipped with all the necessary tools. From these, Agents can combine them to complete a task that we assign.

    Still a bit vague, right? A practical example is when you command the Agents to access Facebook every 8 PM, check for any prominent news from friends, and then send a summary to Telegram. That's it!"

    » Read more
  • I just discovered the idb-keyval library that helps implement a key-value database simply. As shared in the series of posts about the process of making OpenNotas, I was struggling to find a type of database for storage, and it seemed quite difficult; in the end, I settled on localForage.

    idb-keyval is quite similar to localForage, but it seems to be doing a little better. For example, it has an update function to update data, simply imagine it like this:

    update('counter', (val) => (val || 0) + 1);

    Unlike the set function, which completely replaces the data.

    » Read more

Introduction

Node.js was first introduced by Ryan Dahl in 2009. And 9 years later, it was also Ryan Dahl who brought another platform called Deno. Like Node, Deno provides a powerful server-side JavaScript runtime environment. In a 2018 video, Ryan Dahl gave a presentation on "10 Things I Regret About Node.js" just before announcing Deno.

So why was Deno created if Node.js was already good enough? In today's article, I would like to extract 5 things that Ryan Dahl regrets about doing/not doing with Node.js.

NPM and package.json

NPM & package.json

After going through many ups and downs, Node.js and npm are like a team that always goes together. npm is known as a repository of dependencies for Node. npm is a centralized and controlled repository.

Because of its centralization, npm has often become a target for attacks aimed at injecting malicious code into packages, such as the case of Popular NPM Package Hijacked to Publish Crypto-mining Malware or attacks aimed at deleting user data like Dev Sabotages Popular NPM Package to Protest Russian Invasion.

Npm came up with package.json, which is a file that records information such as the packages used, license information, repository, description, and many other seemingly unnecessary details.

node_modules

node_modules black hole

Have you ever heard the comparison of node_modules to a black hole in the universe? Or if you have about 10 Node.js projects on your machine, it means you're ready to have 10 more black holes.

node_modules is a directory created to store all the necessary packages for a project. It doesn't use a centralized storage called NODE_PATH, but instead stores them in each project. Even the father of Node.js admits that node_modules is an irreparable mistake and apologizes for it.

Promise

Javascript Promise

Node.js did not immediately embrace Promise from the beginning, as evidenced by many APIs in Node still using callbacks for handling asynchronous operations. Nowadays, Promise has become very powerful, especially when combined with async/await, and that is something the father of Node.js regrets but cannot easily fix.

Security

Node.js security

If you run a Node.js application, it will have full access to files/folders, networks, and environment variables. Obviously, this can be a security risk if you accidentally run a project that contains malicious code, or attackers can exploit this to compromise Node.js servers.

The Build System (GYP)

GYP

The father of Node.js shared that GYP is a very difficult tool to build with, but because V8 of Chrome initially used GYP, Chrome eventually removed it, leaving Node.js as the only user of GYP.

To perform tasks outside the Event Loop, we have to directly interact with V8 by building C++ Addons. Many people complained about this and suggested switching to a more user-friendly solution like the Foreign Function Interface (FFI), but unfortunately, he overlooked them.

He also shared that he didn't like libuv because it uses autotools!?

Conclusion

Some mistakes can be fixed, but some cannot. This article presents 5 mistakes that the father of Node.js shares with us to let us know what he regrets. But no matter what, Node.js has grown and has a solid position in the global community and industry.

References:

Premium
Hello

5 profound lessons

Every product comes with stories. The success of others is an inspiration for many to follow. 5 lessons learned have changed me forever. How about you? Click now!

Every product comes with stories. The success of others is an inspiration for many to follow. 5 lessons learned have changed me forever. How about you? Click now!

View all

Subscribe to receive new article notifications

or
* The summary newsletter is sent every 1-2 weeks, cancel anytime.

Comments (3)

Leave a comment...
Avatar
Thành Đỗ2 years ago
Có một sự thật là Ryan đã khắc phục tất cả vấn đề trên với Deno. Mà de-no <=> no-de 😁
Reply
Avatar
Long Domi2 years ago
Cái node gyp kia luôn là ác mộng, lúc build lỗi ấy
Reply
Avatar
Vũ Mạnh Đức2 years ago
Node_modules so sánh với black hole hài hước
Reply
Scroll or click to go to the next page