Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
timer SALE ENDS IN
0 Days
:
00 Hours
:
00 Minutes
:
00 Seconds
Arrow up icon
GO TO TOP
Building Microservices with Node.js

You're reading from   Building Microservices with Node.js Explore microservices applications and migrate from a monolith architecture to microservices

Arrow left icon
Product type Paperback
Published in May 2024
Publisher Packt
ISBN-13 9781838985936
Length 324 pages
Edition 1st Edition
Languages
Tools
Arrow right icon
Author (1):
Arrow left icon
Daniel Kapexhiu Daniel Kapexhiu
Author Profile Icon Daniel Kapexhiu
Daniel Kapexhiu
Arrow right icon
View More author details
Toc

Table of Contents (23) Chapters Close

Preface 1. Part 1: Understanding Microservices and Node.js
2. Chapter 1: Introducing Microservices FREE CHAPTER 3. Chapter 2: Exploring the Core Principles of Microservices 4. Chapter 3: Understanding Node.js Fundamentals: Building Blocks and Key Concepts 5. Chapter 4: Leveraging the JavaScript and Node.js Ecosystem for Microservices Development 6. Part 2: Building and Integrating Microservices with Node.js
7. Chapter 5: Knowing the Infrastructure of Microservices in Node.js 8. Chapter 6: Designing Microservices Architecture in Node.js 9. Chapter 7: Integrating Microservices in Node.js Applications 10. Chapter 8: Debugging Microservices in Node.js 11. Part 3: Data Management in Microservices Using Node.js
12. Chapter 9: Database Manipulation in Microservices with Node.js 13. Chapter 10: API Communication and Data Contracts in Microservices 14. Chapter 11: Caching and Asynchronous Messaging in Microservices 15. Chapter 12: Ensuring Data Security with the Saga Pattern, Encryption, and Security Measures 16. Part 4: Monitoring and Logging in Microservices with Node.js
17. Chapter 13: Monitoring Microservices in Node.js 18. Chapter 14: Logging in Microservices with Node.js 19. Chapter 15: Interpreting Monitoring Data in Microservices 20. Chapter 16: Analyzing Log Data in Microservices with Node.js 21. Index 22. Other Books You May Enjoy

Introduction to the microservices and decentralized architecture concepts

In this section, we’ll learn about two important concepts: microservices and decentralized architecture.

Microservices is an architectural style and approach to building software applications as a collection of small, loosely coupled, and independently deployable services. Meanwhile, in decentralized architecture, components or services are distributed across multiple nodes or entities.

Both microservices architecture and decentralized architecture promote modularity, scalability, fault tolerance, and autonomy. While microservices focus on building applications as a collection of small services, decentralized architecture focuses on distributing processing and decision making across multiple nodes. These architectural approaches can be combined to build highly scalable, resilient, and flexible systems that can adapt to changing requirements and handle complex workloads.

Let’s start with the microservices architecture.

Microservices architecture

In a microservices architecture, the application is broken down into multiple small services, each responsible for a specific business capability. These services are developed, deployed, and managed independently, communicating with one another through well-defined application programming interfaces (APIs) or message-based protocols.

Figure 1.1 shows a typical microservices architecture compared to a typical monolithic architecture.

Figure 1.1: A typical microservices architecture

Figure 1.1: A typical microservices architecture

In Node.js, microservices are typically developed using lightweight frameworks such as Express.js or Fastify. Each microservice is a separate application with its own code base and can be developed, deployed, and scaled independently. Microservices can be written in different programming languages such as Java and Python, but Node.js is often chosen due to its efficiency, event-driven nature, and large ecosystem of modules.

The key characteristics of microservices include the following:

  • Modularity: Microservices promote a modular approach, where each service is self-contained and focuses on a specific business functionality. Services can be developed, updated, and scaled independently, allowing for flexibility and easy maintenance.
  • Loose coupling: Microservices are loosely coupled, meaning they have minimal dependencies on one another. They communicate through well-defined interfaces, typically using lightweight protocols such as RESTful APIs or messaging systems. This loose coupling enables services to evolve and scale independently without affecting the entire system.
  • Independently deployable: Each microservice can be deployed independently of other services. This allows for rapid deployment and reduces the risk of system-wide failures. It also enables teams to work on different services simultaneously, promoting faster development cycles and continuous deployment practices.
  • Polyglot architecture: Microservices architecture allows for the use of different technologies, programming languages, and frameworks for each service. This flexibility allows teams to select the most appropriate technology stack for a specific service, based on its requirements and characteristics.
  • Resilience and fault isolation: Failure in one microservice does not bring down the entire system. Faults or errors in one service are isolated and do not propagate to other services. This enhances the overall resilience and fault tolerance of the system.

Understanding these key characteristics is essential for designing, developing, and maintaining successful microservices architectures. Embracing these principles can lead to more scalable, resilient, and agile software systems that meet the demands of modern application development.

Now that you’ve been introduced to the concept of microservices architecture and learned about its key characteristics, let’s dive into the next concept: decentralized architecture.

Decentralized architecture

Decentralized architecture, also known as distributed architecture, refers to an architectural approach where components or services are distributed across multiple nodes or entities rather than being centrally managed. This promotes autonomy, scalability, and fault tolerance by distributing processing, data, and decision making across multiple nodes.

Centralized architectures have a single point of control, making them easier to manage but potentially less scalable and more vulnerable to failures. Decentralized architectures distribute control and data, offering better scalability, fault tolerance, and performance, especially in large and dynamic systems.

Examples of centralized architectures include traditional client-server architectures, where clients communicate with a central server. Mainframes and many early computing systems followed centralized architectures.

Examples of decentralized architectures include blockchain networks, peer-to-peer file-sharing systems, and certain types of distributed databases. Also, some modern microservices architectures follow decentralized principles where services can function independently.

Figure 1.2 shows a typical decentralized architecture:

Figure 1.2: A typical decentralized architecture

Figure 1.2: A typical decentralized architecture

The key aspects of a decentralized architecture include the following:

  • Distribution of responsibilities: In a decentralized architecture, responsibilities and tasks are distributed across multiple nodes or entities. Each node operates independently and is responsible for specific functions or services. This distribution allows for better resource utilization and can improve fault tolerance and performance.
  • Autonomy and independence: Nodes in a decentralized architecture have a certain degree of autonomy and can operate independently. They can make decisions, process data, and provide services without relying on central coordination. This autonomy allows the system to function even if connectivity to other nodes is disrupted.
  • Peer-to-peer communication: Decentralized architectures often rely on peer-to-peer communication between nodes. Nodes can interact directly with each other, exchanging messages, data, or resources without the need for a centralized intermediary. Peer-to-peer communication enables decentralized decision making, data sharing, and collaboration.
  • Scalability and load distribution: Decentralized architectures can scale horizontally by adding more nodes to handle increased workloads. As the system grows, new nodes can be added, distributing the load and allowing for improved scalability and performance. This scalability makes decentralized architectures well suited for handling large-scale applications or systems with dynamic resource demands.
  • Resilience and fault tolerance: Decentralized architectures offer better resilience and fault tolerance compared to centralized architectures. If one node fails or becomes unavailable, the system can continue to function by routing requests or tasks to other available nodes. Nodes can recover independently, and failures are less likely to affect the entire system.
  • Security and privacy: Decentralized architectures can provide enhanced security and privacy compared to centralized architectures. Distributed data storage and communication patterns make it more challenging for attackers to compromise the system or gain unauthorized access to sensitive information. Additionally, decentralized systems can allow users to maintain more control over their data and identities.

Understanding these key aspects is crucial when designing and implementing decentralized architectures. By leveraging the benefits of distribution, autonomy, and scalability, organizations can build robust and flexible systems capable of handling modern computing challenges.

In the next section, we’ll explore the principles of service boundaries and loose coupling.

You have been reading a chapter from
Building Microservices with Node.js
Published in: May 2024
Publisher: Packt
ISBN-13: 9781838985936
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime