Node.js is rapidly becoming one of the most popular platforms for building fast, scalable web and mobile applications. In fact, the 2017 Node.js User Survey reveals that there are currently over 7 million Node.js instances online, with three in four users planning to increase their use of Node.js in the next 12 months. And it’s easy to see why: 68 percent of those users say Node.js improves developer productivity, 58 report it reduces development costs, and 50 percent say it increases application performance.
As Node.js increasingly becomes the preferred technology for application development, the demand for expert Node.js developers will also continue to increase. But while plenty has been written about what Node.js can do, how developers can get started using it, and why it has become a core server-side technology with some of the world’s biggest corporations—there’s not much that’s been written to help beginner or intermediate Node.js developers take their skills to the next level. Until now.
In our latest eBook, Advanced Node.js: Optimize, Deploy, and Maintain an Enterprise-Scale Node.js Application, we share advanced techniques for launching and running an enterprise-scale product, service, or brand built on Node.js.
This is a topic that has not, in our opinion, gotten the attention and expert insights it deserves. In most cases, the post-launch journey is far longer and has a bigger impact than the development process itself. This stage also determines whether a Node.js application will succeed or fail at delivering on the business value the technology promises.
The eBook provides a practical foundation for success during the critical first three months or so of a successful Node.js journey—the time span that covers the period from pre-production planning to continuous deployment and testing.
Specifically, the eBook offers tips, tricks and best practices for each of the following critical points:
1. Preparing for Production Launch
Preparing for a release is always a critical point in any application development journey, and that’s certainly the case for Node.js projects. It’s your team’s final opportunity to find and fix issues before they impact your deployment process, your end users, or the business itself.
The eBook walks users through a pre-release process with the following areas of emphasis:
Optimizing Your Code
Best Practices for Error Handling
Confirming Your Code Meets Security Requirements
Configuring for a Production Environment
When it comes to code optimization, one of the many pre-production best practices detailed in the eBook is a process called “linting.” This entails running an automated code quality tool—such as ESLint or JShint—through your codebase. It usually covers only very basic quality issues, but that’s the point: It catches avoidable—and usually very easy-to-fix—errors before they put a production application at risk.
2. The First 24 Hours of Your Node.js Deployment
After covering the fundamentals of an effective pre-production workflow, we next look at what to expect and how to respond during the critical first 24 hours after deployment.
Deploying an enterprise application can be harrowing. After all, XebiaLabs’ Application Release Automation Trends survey revealed that up to 30 percent of all application deployments fail. Meanwhile, the Trends in DevOps, Continuous Delivery & Application Release Automation survey revealed that 77 percent of organizations have software production release problems. Clearly, anyone tasked with deploying an application should be ready for things to go wrong—perhaps very wrong.
While a robust pre-production process can help minimize the impact of bugs, configuration failures, and other avoidable problems, expert Node.js developers must know how to address common “Day One” deployment problems—particularly those that result in crashes or other high-impact issues.
Typical problems that may arise within the first 24 hours include:
Crashing Node.js Processes
Exceeding API Rate Limits
Troubleshooting WebSocket Issues
File Upload Issues
The good news about these Day One surprises (and there will be surprises) is that you’re going to learn a lot about building better Node.js applications and about deploying your applications with fewer post-deployment issues. While problems can and will continue to happen in the future, truly serious problems will probably be fewer and farther between.
Even better news is that once you effectively troubleshoot these Day One issues, you’ll be dealing with a more stable and reliable application. That, in turn, frees you to focus on ways to improve your application’s performance and to upgrade your own process for building, testing, and deploying Node.js applications.
3. Ongoing Management
Having successfully deployed, the final chapter of the eBook looks at the ongoing management of your Node.js application. While this isn’t too different from any other application rollout, there are a couple of specifics you should watch out for:
Managing Node.js Concurrency
As we discuss in the eBook, application performance monitoring (APM) is vital to maintain the stability of your application deployment and to detect subtle regressions that may result in application slow-down or outright failure if left unchecked. An APM solution like AppDynamics can offer end-to-end insight into application behavior and provide specific monitoring capabilities for the Node.js stack.
Read all the best practices for deploying and managing your Node.js applications in our latest eBook, Advanced Node.js: Optimize, Deploy, and Maintain an Enterprise-Scale Node.js Application.