Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Building Microservices with Node.js
Building Microservices with Node.js

Building Microservices with Node.js: Explore microservices applications and migrate from a monolith architecture to microservices

eBook
$9.99 $29.99
Paperback
$36.99
Subscription
Free Trial
Renews at $19.99p/m

What do you get with Print?

Product feature icon Instant access to your digital eBook copy whilst your Print order is Shipped
Product feature icon Paperback book shipped to your preferred address
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
Product feature icon AI Assistant (beta) to help accelerate your learning
OR
Modal Close icon
Payment Processing...
tick Completed

Shipping Address

Billing Address

Shipping Methods
Table of content icon View table of contents Preview book icon Preview Book

Building Microservices with Node.js

Introducing Microservices

Microservices, or microservices architecture, is an architectural style for designing and building software applications as a collection of small, independent, and loosely coupled services. Microservices offer benefits such as scalability, agility, independent development, and improved fault tolerance. However, they also introduce challenges such as service orchestration, distributed data management, and increased complexity in system design and testing. The successful implementation of microservices requires careful consideration of the specific application requirements and a well-defined architectural strategy.

In this book, we are going to learn about microservices in general and how to architect and develop microservices in Node.js. The book is suitable for backend developers, full-stack developers, software architects, and frontend developers who want to get into the world of backend development and extend their capabilities. You will learn, in an in-depth manner, the major tips and tricks to learn how to build microservices architecture using Node.js. At the end of this book, you will be able to conceptualize, plan, and architect microservices using Node.js, as well as develop and debug them. These are the major skills that companies want their employees to have in order to design the perfect solution for every problem every time.

We’ll start this chapter with an introduction to microservices and decentralized architectures. We’ll also learn about some key concepts in microservices, such as service boundaries, loose coupling, scalability, resilience, and independent data management. Finally, we’ll overview some important abilities in microservices, including independent development and deployment, polyglot architecture, APIs, and continuous integration (CI).

By the end of this chapter, you’ll have learned the fundamentals of microservices and why they are so useful.

In this chapter, we’re going to cover the following main topics:

  • Introduction to the microservices and decentralized architecture concepts
  • Service boundaries and loose coupling
  • Independent development and deployment and polyglot architecture
  • Scalability and resilience and independent data management
  • APIs and communication and CI

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.

Service boundaries and loose coupling

Service boundaries and loose coupling are key principles in software architecture, especially in the context of microservices. Let’s explore these concepts in more detail.

Service boundaries

Service boundaries refer to the logical or functional divisions within a software system, where each boundary represents a separate and independent service. In a microservices architecture, services are designed around specific business capabilities or bounded contexts. Each service is responsible for a well-defined set of functions, operations, or data.

The concept of service boundaries offers several benefits, such as the following:

  • Modularity and maintainability: Service boundaries help break down a complex system into smaller, more manageable parts. Each service can be developed, deployed, and maintained independently, allowing for better modularity and ease of maintenance.
  • Scalability and performance: By dividing the system into services based on specific business capabilities, it becomes easier to scale individual services horizontally or vertically to meet varying demands. Services can be independently scaled to optimize resource utilization and improve overall system performance.
  • Autonomy and team independence: Service boundaries enable cross-functional teams to work independently on different services. Each team can focus on its service requirements, technologies, and development practices, leading to faster development cycles and improved team autonomy.
  • Flexibility and technological diversity: With clear service boundaries, teams can select the most suitable technologies, programming languages, or frameworks for each service based on their specific needs. This promotes technological diversity and allows for the use of the right tool for each job.
  • Fault isolation and resilience: Service boundaries help contain failures within individual services. If a service encounters an issue or fails, it does not impact the entire system. Other services can continue to function independently, promoting fault isolation and overall system resilience.

Understanding and defining clear service boundaries are critical for successful microservices architectures. By focusing on modular and independent services, organizations can build scalable, maintainable, and adaptable systems that align with their business needs and support effective teamwork.

Loose coupling

Loose coupling is a design principle that emphasizes reducing dependencies between software components or services. It allows components to interact with one another with minimal knowledge of one another’s internal workings. Loose coupling promotes independence, flexibility, and adaptability within a system.

Here are some key aspects of loose coupling:

  • Well-defined interfaces: Components communicate through well-defined interfaces or contracts, such as APIs, message formats, or events. The interfaces abstract away implementation details, allowing components to interact based on agreed-upon contracts rather than tight integration.
  • Minimal dependencies: Components have minimal dependencies on other components or services. They rely only on the specific data or functionality required for their operations, reducing interdependencies.
  • Decoupled development and deployment: Loose coupling enables independent development and deployment of components or services. Changes in one component have minimal impact on others, allowing for faster iterations, easier updates, and more frequent deployments.
  • Replaceability and extensibility: With loose coupling, components can be easily replaced or extended without affecting the entire system. New components can be introduced, and existing components can be modified or upgraded with minimal disruption.
  • Testability and isolation: Loose coupling promotes testability by enabling the testing of components in isolation. Dependencies can be mocked or stubbed, allowing for focused unit testing and validation of individual components.

By achieving loose coupling, systems become more modular, maintainable, and adaptable. This enables independent development and deployment, enhances scalability and resilience, and supports the seamless evolution of the software architecture over time.

Figure 1.3 shows the architecture of loosely coupled services:

Figure 1.3: Loosely coupled services

Figure 1.3: Loosely coupled services

In Figure 1.3, each circle represents a component.

Service boundaries and loose coupling are closely related concepts in the context of building scalable and maintainable software systems. By defining clear service boundaries and ensuring loose coupling between services and components, organizations can create flexible, modular architectures that enable agility, scalability, and independent development.

In the next section, we’ll dive into independent development and deployment and polyglot architecture.

Independent development and deployment and polyglot architecture

Independent development and deployment and polyglot architecture are some of the crucial abilities to succeed with microservices. Independent development and deployment allows teams to do the work autonomously. With a polyglot architecture, teams can use the best programming languages, frameworks, and so on, to deliver the software in its best quality.

Independent development and deployment

Independent development and deployment refers to the ability to develop and deploy individual components or services of a software system independently, without tightly coupling them to other components. This approach is a fundamental principle in microservices and allows teams to work autonomously, focusing on specific services or functionalities.

Here are some key aspects and benefits of independent development and deployment:

  • Team autonomy: Independent development and deployment empower cross-functional teams to work autonomously, allowing for making decisions and implementing changes without excessive coordination with other teams. Each team can focus on their specific service or functionality, leading to faster development cycles and improved productivity.
  • Faster iterations and releases: Independent development allows teams to work on their own release schedules, enabling faster iterations and frequent releases. Teams can deploy updates and new features to their respective services without waiting for the entire system to be released. This promotes agility, enables rapid experimentation, and allows for faster response to user feedback.
  • Reduced interdependencies: Independent development reduces the interdependencies between teams and components. Teams can make changes, updates, or fixes to their services without impacting other services or the overall system. This isolation helps minimize the risk of regression and makes it easier to identify and resolve issues.
  • Improved fault isolation: When components are developed and deployed independently, failures or issues in one component are isolated and do not cascade to other components. This improves fault isolation and resilience, as failures are contained within the affected service, minimizing the impact on the rest of the system.
  • Scalability and resource optimization: Independent development and deployment allow teams to scale individual services independently based on their specific needs. Resources can be allocated to high-demand services, while less resource-intensive services can operate with minimal resources. This fine-grained scalability optimizes resource utilization and improves overall system performance.

Understanding the significance of independent development and deployment is crucial for embracing agile development practices and building scalable, adaptable, and maintainable software systems. Empowering teams to work independently enhances productivity, innovation, and collaboration, ultimately leading to successful outcomes in a rapidly evolving technological landscape.

Now, let’s take a look at the concept and key aspects of polyglot architecture.

Polyglot architecture

Polyglot architecture refers to the practice of using multiple programming languages, technologies, and frameworks within a software system. In a polyglot architecture, different services or components may be implemented using different languages or technologies that best fit their specific requirements.

Here are some key aspects and benefits of polyglot architecture:

  • Technology fit: Different services or components may have varying requirements, such as performance, scalability, or integration with external systems. Polyglot architecture allows teams to select the most appropriate technology stack for each service, leveraging the strengths of different languages or frameworks. This technology fit can result in more efficient and optimized solutions.
  • Specialization: Polyglot architecture enables teams to leverage the expertise and strengths of individual team members. If a team has expertise in a particular language or framework, they can use it for their service, promoting specialization and maximizing the team’s productivity and efficiency.
  • Flexibility and innovation: By embracing a polyglot architecture, organizations can explore and adopt new technologies, frameworks, or programming languages. This fosters a culture of innovation and keeps the development team up to date with the latest advancements in the tech industry.
  • Reuse and integration: Polyglot architecture allows for the integration of existing systems or services developed using different technologies. It facilitates the reuse of legacy systems or external components, enabling seamless integration within the overall architecture.
  • Avoiding vendor lock-in: Using multiple technologies helps reduce reliance on a single vendor or technology stack. It mitigates the risks associated with vendor lock-in and provides the flexibility to switch technologies or vendors if needed.

However, adopting a polyglot architecture also comes with challenges, such as increased complexity in terms of deployment, maintenance, and collaboration across teams with diverse technology stacks. Proper governance, documentation, and knowledge-sharing practices are necessary to ensure effective coordination and mitigate potential drawbacks.

Figure 1.4 shows a simple polyglot architecture:

Figure 1.4: A simple polyglot architecture

Figure 1.4: A simple polyglot architecture

Overall, independent development and deployment, along with a polyglot architecture, empowers teams to work autonomously, leverage the best-fit technologies, and deliver software systems that are scalable, efficient, and aligned with the specific requirements of each component or service.

In the next section, we look at some additional crucial aspects: scalability, resilience, and independent data management.

Scalability and resilience and independent data management

Scalability and resilience are some key concepts in microservices to keep in mind while building robust and high-performing software. Also, in microservices, every service has its own database, so every data storage is independent.

Scalability and resilience

Scalability and resilience are crucial aspects of building robust and high-performing software systems. Let’s explore these concepts in more detail.

Scalability refers to the ability of a system to handle increased workloads and accommodate growing demands without sacrificing performance. It involves the capability to scale up or scale out the system to ensure optimal resource utilization and responsiveness.

Here are key considerations for achieving scalability:

  • Horizontal scaling: Horizontal scaling involves adding more instances or nodes to distribute the workload across multiple servers or machines. It allows for increased throughput and improved performance by handling requests in parallel.
  • Vertical scaling: Vertical scaling, also known as scaling up, involves increasing the resources (such as CPU, memory, or storage) of individual instances to handle higher workloads. Vertical scaling can be achieved by upgrading hardware or utilizing cloud-based services that offer scalable resource provisioning.
  • Load balancing: Load balancing mechanisms distribute incoming requests across multiple instances to ensure an even distribution of workloads and prevent overload on any single component. Load balancers intelligently route requests based on factors such as server health, capacity, or response time.
  • Caching: Implementing caching mechanisms, such as in-memory caches or content delivery networks (CDNs), can significantly improve scalability. Caching reduces the load on backend services by storing frequently accessed data or computed results closer to the users, thereby reducing the need for repeated processing.
  • Asynchronous processing: Offloading long-running or resource-intensive tasks to asynchronous processing systems, such as message queues or background workers, helps improve scalability. By processing tasks asynchronously, the system can handle a larger number of concurrent requests and optimize resource utilization.
  • Resilience: Resilience refers to the system’s ability to recover from failures, adapt to changing conditions, and continue to operate reliably. Resilient systems are designed to minimize the impact of failures and maintain essential functionality. Consider the following factors for building resilient systems:
    • Redundancy and replication: Replicating critical components or data across multiple instances or nodes ensures redundancy and fault tolerance. If one instance fails, others can seamlessly take over to maintain system availability and prevent data loss.
    • Fault isolation: Designing systems with well-defined service boundaries and loose coupling ensures that failures or issues in one component do not propagate to others. Fault isolation prevents the entire system from being affected by localized failures.
    • Failure handling and recovery: Implementing robust error handling and recovery mechanisms is essential for resilience. Systems should be able to detect failures, recover automatically if possible, and provide clear feedback to users or downstream components.
    • Monitoring and alerting: Continuous monitoring of system health, performance, and error rates helps identify issues or potential failures in real time. Proactive alerting mechanisms can notify appropriate personnel when anomalies or critical events occur, allowing for timely intervention and mitigation.
    • Graceful degradation and circuit breakers: Systems should be designed to gracefully degrade functionality when facing high loads or failure conditions. Circuit breakers can be implemented to automatically stop sending requests to a failing component or service, reducing the impact on the system and allowing it to recover.

Scalability and resilience are closely interconnected. Scalable systems are often designed with resilience in mind, and resilient systems can better handle increased workloads through scalable architecture. By incorporating these characteristics into their designs, developers can create robust and reliable software systems capable of adapting to changing demands and providing a positive user experience even in challenging conditions.

Independent data management

Independent data management refers to the practice of managing data within individual services or components in a decentralized manner. In a microservices architecture, each service typically has its own data store or database, and the responsibility for data management lies within the service boundary.

Here are key considerations for independent data management:

  • Data ownership and autonomy: Each service is responsible for managing its own data, including data storage, retrieval, and modification. This promotes autonomy and allows teams to make independent decisions regarding data models, storage technologies, and data access patterns.
  • Decentralized data stores: Services may use different types of databases or storage technologies based on their specific needs. For example, one service may use a relational database, while another may use a NoSQL database (see Chapter 9) or a specialized data store optimized for specific use cases.
  • Data consistency and synchronization: When data is distributed across multiple services, ensuring data consistency can be challenging. Techniques such as eventual consistency, distributed transactions, or event-driven architectures can be employed to synchronize data across services and maintain data integrity.
  • Data access and communication: Services communicate with each other through well-defined APIs or message-based protocols to access and exchange data. Service boundaries should have clear contracts and APIs for data exchange, enabling services to interact while maintaining loose coupling.
  • Data security and access control: Each service should enforce appropriate security measures and access controls to protect its data. Implementing authentication, authorization, and encryption mechanisms ensures data privacy and security within the service boundaries.
  • Data integration and aggregation: While services manage their own data, there may be situations where data from multiple services needs to be aggregated or integrated for specific use cases. Techniques such as data pipelines, data warehouses, or event-driven architectures can facilitate data integration and aggregation across services.

Independent data management allows services to evolve and scale independently, promotes team autonomy, and reduces interdependencies between services.

Figure 1.5 shows the data management process:

Figure 1.5: Data management process

Figure 1.5: Data management process

However, the data management process also introduces challenges related to data consistency, synchronization, and overall system-wide data coherence. Organizations should carefully design data management strategies and employ appropriate patterns and technologies to address these challenges while maintaining the benefits of independent data management.

In the next section, we’ll learn about APIs, communication, and CI.

APIs and communication and CI

API stands for application programming interface. It is a set of rules and protocols that allows different software applications to communicate and interact with one another. APIs define how different software components should interact, what data they can exchange, and what operations they can perform. CI is a common software practice that allows contributors from all over the world to contribute to one shared code repository.

APIs and communication

APIs play a vital role in enabling communication and interaction between different components, services, or systems within a software architecture. APIs define how different entities can interact with one another, exchange data, and invoke functionalities.

Here are the key considerations related to APIs and communication:

  • API design and documentation: Well-designed APIs follow standards and best practices (see Chapter 10), ensuring clarity, consistency, and ease of use for developers. Comprehensive API documentation, including endpoint details, request/response formats, authentication requirements, and error handling, helps developers understand and utilize APIs effectively.
  • API gateway: An API gateway acts as an entry point for client applications to access multiple APIs. It provides a centralized interface, handles authentication, security, request routing, and rate limiting, and can perform tasks such as caching, logging, and monitoring. API gateways simplify client-side interactions and improve overall API management.
  • API versioning: As APIs evolve over time, it’s essential to implement versioning strategies to maintain backward compatibility. Versioning allows clients to use the desired API version while ensuring existing clients remain unaffected by changes.
  • Authentication and authorization: APIs often require authentication and authorization mechanisms to ensure secure access. Common approaches include API keys, tokens (such as JWT), OAuth, or integration with identity and access management systems. Proper authentication and authorization prevent unauthorized access and protect sensitive data.
  • Data formats and protocols: APIs can utilize various data formats, such as JavaScript Object Notation (JSON), Extensible Markup Language (XML), or protocol buffers, based on the requirements and compatibility with client applications. Similarly, communication protocols such as representational state transfer (REST), GraphQL, or message queues (e.g., RabbitMQ, Apache Kafka) (see Chapter 10) can be chosen depending on the use case. For instance, the most common use cases for REST APIs are web APIs.
  • Asynchronous communication: Asynchronous communication patterns, such as message queues or publish-subscribe systems, can be employed to enable loose coupling and decoupled communication between components or services. These patterns support event-driven architectures and improve scalability, responsiveness, and fault tolerance.

APIs provide a way for developers to access the functionality of a system or service without having to understand its internal implementation details. They abstract the underlying complexity and provide a standardized interface that allows applications to request and exchange data in a consistent and predictable manner.

Figure 1.6 shows an example of a REST API:

Figure 1.6: A REST API

Figure 1.6: A REST API

APIs play a fundamental role in modern software development, enabling seamless integration and collaboration between different systems. They provide a way to access data and services from external sources, allowing applications to extend their functionality and interact with a wide range of services and resources.

CI

CI is a software development practice that involves frequently integrating code changes from multiple developers into a shared code repository. The key goal of CI is to automate the integration process and detect integration issues early.

Here are the key aspects of CI:

  • Version control system (VCS): CI relies on a robust VCS (such as Git) to manage code changes, branches, and version history. Developers commit their code changes to the repository frequently, ensuring a reliable source of code for integration.
  • Automated builds: CI involves setting up automated build processes that compile, test, and package the software based on triggers, such as code commits. Automated build systems, such as Jenkins, Travis CI, or GitLab CI/CD (see Chapter 11), pull the latest code from the repository and build the application in a consistent and repeatable manner.
  • Automated testing: CI encourages automated testing practices, such as unit testing, integration testing, and functional testing. Test suites are executed as part of the build process to ensure that code changes do not introduce regressions and maintain the overall quality of the software.
  • CI server: A CI server or CI/CD platform orchestrates the CI process, monitors code changes, triggers builds, runs tests, and provides feedback to the development team. It generates reports, alerts, and notifications for build failures or test errors.
  • Code quality checks: CI can incorporate static code analysis tools to identify code smells, maintain code style consistency, and enforce best practices. These tools analyze the code base for potential issues, including code complexity, security vulnerabilities, and adherence to coding guidelines.
  • Artifact management: CI involves generating deployable artifacts, such as binaries, container images, or deployment packages, that can be easily deployed to various environments. Artifact management systems, such as Nexus or JFrog Artifactory, help manage and store these artifacts.
  • CI pipelines: CI pipelines define the stages and steps of the CI process, including building, testing, code analysis, and artifact generation. CI pipelines can be customized based on project requirements, incorporating specific build, test, and release steps.

Additional reading

Jenkins: https://www.jenkins.io/doc/

Travis CI: https://docs.travis-ci.com/user/for-beginners/

GitLab CI/CD: https://docs.gitlab.com/ee/ci/

Figure 1.7 shows CI in action:

Figure 1.7: CI in action

Figure 1.7: CI in action

The benefits of CI include early detection of integration issues, faster feedback cycles, improved collaboration, and reduced integration complexities. CI ensures that the software remains in a releasable state at all times, enabling teams to deliver high-quality software with speed, reliability, and reduced risks.

Summary

Microservices and Node.js are two powerful concepts that can greatly impact the development of modern software systems. Here is a summary of the key points to consider when exploring the combination of microservices and Node.js:

  • Microservices: Microservices is an architectural approach where complex applications are built as a collection of small, independent services. Each service focuses on a specific business capability, can be developed and deployed independently, and communicates with other services through well-defined APIs or messaging protocols. Microservices offer benefits such as modularity, scalability, fault isolation, and autonomy, allowing for faster development cycles, easier maintenance, and flexibility in technology selection.
  • Node.js: Node.js is a JavaScript runtime built on the V8 engine, designed for server-side development. It provides an event-driven, non-blocking I/O model that allows for highly scalable and performant applications. Node.js is well-suited for microservices due to its lightweight, asynchronous nature, which enables handling multiple concurrent requests efficiently. Its rich ecosystem of packages and frameworks, along with its support for JavaScript on both the client and server sides, make it a popular choice for microservices development.
  • Combining microservices and Node.js: When combining microservices with Node.js, developers can take advantage of Node.js’s event-driven architecture and ecosystem to build scalable and responsive microservices. Node.js’s non-blocking I/O model allows services to handle high levels of concurrency, making it well-suited for microservices communication and interactions. Its extensive package manager, npm, provides a wide range of libraries and tools to facilitate the development of microservices architectures.
  • Working with microservices and Node.js: When working with microservices and Node.js, it is important to consider various aspects, including service boundaries, loose coupling, API design, data management, scalability, resilience, monitoring, and security. Properly defining service boundaries, ensuring loose coupling between services, designing robust APIs, and managing data independently are crucial for building scalable and maintainable microservices architectures. Implementing strategies for scalability, resilience, monitoring, and security enhances the performance, reliability, and security of the overall system.

In summary, leveraging the power of microservices and Node.js can enable the development of flexible, scalable, and maintainable software systems. By embracing the modular nature of microservices and harnessing the asynchronous capabilities of Node.js, developers can build highly responsive, distributed applications that can adapt to changing requirements and handle complex workloads effectively.

In the next chapter, we’ll cover the core principles of microservices. We’ll dive into more details about microservices and its best practices while developing in Node.js.

Quiz time

  • What are the key characteristics of microservices?
  • What are some key aspects and benefits of independent development and deployment?
  • What is a polyglot architecture?
  • What are APIs?
Left arrow icon Right arrow icon
Download code icon Download Code

Key benefits

  • Explore microservices architecture and implement it using Node.js for robust web applications
  • Follow clear, practical examples and real-world use cases to apply your knowledge and build your skills
  • Excel in the world of software development and tackle complex challenges with confidence
  • Purchase of the print or Kindle book includes a free PDF eBook

Description

– Immerse yourself in the world of microservices with this guide to migration from a monolithic architecture to microservices. – With this book, you’ll acquire a deep understanding of microservices architecture and apply it confidently in your web application projects. – As you progress, you’ll be guided through the process of creating a simple application and incorporating the Node.js framework into it, along with its commonly used libraries. – You’ll learn how the framework operates, how to configure it, and how to develop handlers for the web framework and explore how to deploy your application to a production server. – Get to grips with the intricacies of JavaScript and Node.js and find out how to approach microservices in Node.js, implement them effectively, and integrate RESTful APIs. – Gain insights into service-to-service authentication and authorization and learn how to work with databases and caching, as well as with monitoring and logging in microservices with Node.js. – By the end of this microservices book, you’ll be able to develop a web app using the Node.js framework, configure it, extend it using libraries available for this framework, and launch it using best practices.

Who is this book for?

– This book is for backend developers, full-stack developers, software architects, and frontend developers who want to venture into the world of backend development and extend their capabilities. – A fundamental understanding of the JavaScript ecosystem will be helpful but not necessary, as this book will cover the essentials of backend development, JavaScript programming, and Node.js.

What you will learn

  • Design domain-oriented microservices using domain-driven design (DDD)
  • Understand collaboration techniques for inter-microservice communication and learn how to design an API gateway
  • Automate microservice integration and deployment
  • Split a monolith safely into microservices and understand how to test microservices effectively
  • Use and implement microservices in Kubernetes and Docker environments
  • Get to grips with best practices for maintaining microservices at scale
Estimated delivery fee Deliver to Ukraine

Economy delivery 10 - 13 business days

$6.95

Premium delivery 6 - 9 business days

$21.95
(Includes tracking information)

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : May 03, 2024
Length: 324 pages
Edition : 1st
Language : English
ISBN-13 : 9781838985936
Languages :
Tools :

What do you get with Print?

Product feature icon Instant access to your digital eBook copy whilst your Print order is Shipped
Product feature icon Paperback book shipped to your preferred address
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
Product feature icon AI Assistant (beta) to help accelerate your learning
OR
Modal Close icon
Payment Processing...
tick Completed

Shipping Address

Billing Address

Shipping Methods
Estimated delivery fee Deliver to Ukraine

Economy delivery 10 - 13 business days

$6.95

Premium delivery 6 - 9 business days

$21.95
(Includes tracking information)

Product Details

Publication date : May 03, 2024
Length: 324 pages
Edition : 1st
Language : English
ISBN-13 : 9781838985936
Languages :
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
$19.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
$199.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just $5 each
Feature tick icon Exclusive print discounts
$279.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just $5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total $ 136.97
Building LLM Powered  Applications
$49.99
Mastering Node.js Web Development
$49.99
Building Microservices with Node.js
$36.99
Total $ 136.97 Stars icon
Banner background image

Table of Contents

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

Customer reviews

Rating distribution
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
(4 Ratings)
5 star 75%
4 star 0%
3 star 0%
2 star 0%
1 star 25%
Salman Farsi Jun 04, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
This book provides valuable insights into designing, developing, and deploying microservices using Node.js. Below, I’ll cover the key aspects of the book, its strengths, and areas for improvement:General Introduction: “Building Microservices with Node.js” by David Herron is a practical guide for developers, architects, and system engineers who want to build scalable, resilient, and distributed systems using Node.js. The book covers essential concepts, best practices, and real-world examples related to microservices architecture.Key Topics Covered:Microservices Fundamentals: The book starts by explaining the core principles of microservices, emphasizing autonomy, bounded context, decentralization, and resilience.Node.js Basics: It introduces Node.js fundamentals, including asynchronous programming, event-driven architecture, and the JavaScript ecosystem.Designing Microservices: The author discusses how to break down monolithic applications into smaller, independent services and design them effectively.Communication Strategies: The book covers API contracts, RESTful services, and asynchronous messaging patterns.Data Management and Security: It explores data storage engines (e.g., MySQL, MongoDB) and security considerations.Monitoring and Observability: The author explains monitoring, logging, and analyzing log data in microservices.Serverless Architectures: The book touches on serverless concepts and their integration with microservices.Strengths:Practical Approach: The book provides hands-on examples, code snippets, and real-world scenarios, making it accessible for developers.Node.js Focus: It leverages Node.js as the primary runtime environment, catering to developers familiar with JavaScript.Structured Content: Each chapter follows a logical progression, building on previous concepts.Useful Tips: The author shares practical tips, best practices, and pitfalls to avoid.Areas for Improvement:Depth of Coverage: While the book covers essential topics, some readers might desire more in-depth exploration of specific areas.Advanced Topics: Advanced readers may seek additional content on microservices deployment, Kubernetes, and service mesh integration.Summary: “Building Microservices with Node.js” is a valuable resource for anyone interested in microservices architecture. It strikes a balance between theory and practical implementation, making it suitable for both beginners and experienced developers. While it doesn’t delve into every advanced topic, it provides a solid foundation for building microservices using Node.js.In summary, if you’re looking to enhance your microservices skills with Node.js, this book is a worthwhile read1. Whether you’re a developer, architect, or system engineer, the practical insights and examples will empower you to create robust, scalable systems in the ever-evolving world of microservices.Thank you
Amazon Verified review Amazon
Amazon Customer May 14, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
I highly recommend this book for anyone interested in diving into Node.js applications. It really helps put things into perspective on how microservices architecture is built from the ground up. It’s like a toolkit that shows you how to build the kind of systems that are powering most of the market’s services today. The way it's written makes it super accessible, especially if you're just starting out. Plus, the quality of the book is top-notch, complete with all the extras you need to get a solid grasp of the material.
Amazon Verified review Amazon
Goppinath Thurairajah Jul 13, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
My initial impression is that this book is not only for server-side developers but also covers topics that would interest client-side developers who are curious about understanding the other side of the story.This book is intended for readers with intermediate to advanced knowledge. The material assumes a clear basic understanding of how web technology and RESTful APIs work.Even though the book aims to explain advanced web technologies, particularly Microservices through Node.js, it predominantly focuses on theoretical explanations, making it universally understandable for anyone seeking to grasp the theory and best practices including:- Design domain-specific microservices using domain-driven design (DDD)- Learn how to facilitate communication between microservices and design an API gateway- Automate the integration and deployment of microservices- Safely transition from a monolithic architecture to microservices and understand effective testing strategies for microservices- Implement microservices in Kubernetes and Docker environments- Understand best practices for scaling and maintaining microservicesThe book is logically divided into 16 chapters. The author, Daniel Kapexhiu, begins by introducing Microservices and gradually delves into advanced topics such as understanding, designing, caching, security, and finally, logging and monitoring.In conclusion, the book is a comprehensive resource that benefits not only for server-side developers who would like to expand their knowledge and understanding of the Microservices Architecture but also for any client-side developer who would like to develop a clear understanding of the server-side for better coordination.
Amazon Verified review Amazon
Cristian Jul 03, 2024
Full star icon Empty star icon Empty star icon Empty star icon Empty star icon 1
This book is simply theory and repetition of concepts chapter after chapter.
Subscriber review Packt
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

What is the delivery time and cost of print book? Chevron down icon Chevron up icon

Shipping Details

USA:

'

Economy: Delivery to most addresses in the US within 10-15 business days

Premium: Trackable Delivery to most addresses in the US within 3-8 business days

UK:

Economy: Delivery to most addresses in the U.K. within 7-9 business days.
Shipments are not trackable

Premium: Trackable delivery to most addresses in the U.K. within 3-4 business days!
Add one extra business day for deliveries to Northern Ireland and Scottish Highlands and islands

EU:

Premium: Trackable delivery to most EU destinations within 4-9 business days.

Australia:

Economy: Can deliver to P. O. Boxes and private residences.
Trackable service with delivery to addresses in Australia only.
Delivery time ranges from 7-9 business days for VIC and 8-10 business days for Interstate metro
Delivery time is up to 15 business days for remote areas of WA, NT & QLD.

Premium: Delivery to addresses in Australia only
Trackable delivery to most P. O. Boxes and private residences in Australia within 4-5 days based on the distance to a destination following dispatch.

India:

Premium: Delivery to most Indian addresses within 5-6 business days

Rest of the World:

Premium: Countries in the American continent: Trackable delivery to most countries within 4-7 business days

Asia:

Premium: Delivery to most Asian addresses within 5-9 business days

Disclaimer:
All orders received before 5 PM U.K time would start printing from the next business day. So the estimated delivery times start from the next day as well. Orders received after 5 PM U.K time (in our internal systems) on a business day or anytime on the weekend will begin printing the second to next business day. For example, an order placed at 11 AM today will begin printing tomorrow, whereas an order placed at 9 PM tonight will begin printing the day after tomorrow.


Unfortunately, due to several restrictions, we are unable to ship to the following countries:

  1. Afghanistan
  2. American Samoa
  3. Belarus
  4. Brunei Darussalam
  5. Central African Republic
  6. The Democratic Republic of Congo
  7. Eritrea
  8. Guinea-bissau
  9. Iran
  10. Lebanon
  11. Libiya Arab Jamahriya
  12. Somalia
  13. Sudan
  14. Russian Federation
  15. Syrian Arab Republic
  16. Ukraine
  17. Venezuela
What is custom duty/charge? Chevron down icon Chevron up icon

Customs duty are charges levied on goods when they cross international borders. It is a tax that is imposed on imported goods. These duties are charged by special authorities and bodies created by local governments and are meant to protect local industries, economies, and businesses.

Do I have to pay customs charges for the print book order? Chevron down icon Chevron up icon

The orders shipped to the countries that are listed under EU27 will not bear custom charges. They are paid by Packt as part of the order.

List of EU27 countries: www.gov.uk/eu-eea:

A custom duty or localized taxes may be applicable on the shipment and would be charged by the recipient country outside of the EU27 which should be paid by the customer and these duties are not included in the shipping charges been charged on the order.

How do I know my custom duty charges? Chevron down icon Chevron up icon

The amount of duty payable varies greatly depending on the imported goods, the country of origin and several other factors like the total invoice amount or dimensions like weight, and other such criteria applicable in your country.

For example:

  • If you live in Mexico, and the declared value of your ordered items is over $ 50, for you to receive a package, you will have to pay additional import tax of 19% which will be $ 9.50 to the courier service.
  • Whereas if you live in Turkey, and the declared value of your ordered items is over € 22, for you to receive a package, you will have to pay additional import tax of 18% which will be € 3.96 to the courier service.
How can I cancel my order? Chevron down icon Chevron up icon

Cancellation Policy for Published Printed Books:

You can cancel any order within 1 hour of placing the order. Simply contact customercare@packt.com with your order details or payment transaction id. If your order has already started the shipment process, we will do our best to stop it. However, if it is already on the way to you then when you receive it, you can contact us at customercare@packt.com using the returns and refund process.

Please understand that Packt Publishing cannot provide refunds or cancel any order except for the cases described in our Return Policy (i.e. Packt Publishing agrees to replace your printed book because it arrives damaged or material defect in book), Packt Publishing will not accept returns.

What is your returns and refunds policy? Chevron down icon Chevron up icon

Return Policy:

We want you to be happy with your purchase from Packtpub.com. We will not hassle you with returning print books to us. If the print book you receive from us is incorrect, damaged, doesn't work or is unacceptably late, please contact Customer Relations Team on customercare@packt.com with the order number and issue details as explained below:

  1. If you ordered (eBook, Video or Print Book) incorrectly or accidentally, please contact Customer Relations Team on customercare@packt.com within one hour of placing the order and we will replace/refund you the item cost.
  2. Sadly, if your eBook or Video file is faulty or a fault occurs during the eBook or Video being made available to you, i.e. during download then you should contact Customer Relations Team within 14 days of purchase on customercare@packt.com who will be able to resolve this issue for you.
  3. You will have a choice of replacement or refund of the problem items.(damaged, defective or incorrect)
  4. Once Customer Care Team confirms that you will be refunded, you should receive the refund within 10 to 12 working days.
  5. If you are only requesting a refund of one book from a multiple order, then we will refund you the appropriate single item.
  6. Where the items were shipped under a free shipping offer, there will be no shipping costs to refund.

On the off chance your printed book arrives damaged, with book material defect, contact our Customer Relation Team on customercare@packt.com within 14 days of receipt of the book with appropriate evidence of damage and we will work with you to secure a replacement copy, if necessary. Please note that each printed book you order from us is individually made by Packt's professional book-printing partner which is on a print-on-demand basis.

What tax is charged? Chevron down icon Chevron up icon

Currently, no tax is charged on the purchase of any print book (subject to change based on the laws and regulations). A localized VAT fee is charged only to our European and UK customers on eBooks, Video and subscriptions that they buy. GST is charged to Indian customers for eBooks and video purchases.

What payment methods can I use? Chevron down icon Chevron up icon

You can pay with the following card types:

  1. Visa Debit
  2. Visa Credit
  3. MasterCard
  4. PayPal
What is the delivery time and cost of print books? Chevron down icon Chevron up icon

Shipping Details

USA:

'

Economy: Delivery to most addresses in the US within 10-15 business days

Premium: Trackable Delivery to most addresses in the US within 3-8 business days

UK:

Economy: Delivery to most addresses in the U.K. within 7-9 business days.
Shipments are not trackable

Premium: Trackable delivery to most addresses in the U.K. within 3-4 business days!
Add one extra business day for deliveries to Northern Ireland and Scottish Highlands and islands

EU:

Premium: Trackable delivery to most EU destinations within 4-9 business days.

Australia:

Economy: Can deliver to P. O. Boxes and private residences.
Trackable service with delivery to addresses in Australia only.
Delivery time ranges from 7-9 business days for VIC and 8-10 business days for Interstate metro
Delivery time is up to 15 business days for remote areas of WA, NT & QLD.

Premium: Delivery to addresses in Australia only
Trackable delivery to most P. O. Boxes and private residences in Australia within 4-5 days based on the distance to a destination following dispatch.

India:

Premium: Delivery to most Indian addresses within 5-6 business days

Rest of the World:

Premium: Countries in the American continent: Trackable delivery to most countries within 4-7 business days

Asia:

Premium: Delivery to most Asian addresses within 5-9 business days

Disclaimer:
All orders received before 5 PM U.K time would start printing from the next business day. So the estimated delivery times start from the next day as well. Orders received after 5 PM U.K time (in our internal systems) on a business day or anytime on the weekend will begin printing the second to next business day. For example, an order placed at 11 AM today will begin printing tomorrow, whereas an order placed at 9 PM tonight will begin printing the day after tomorrow.


Unfortunately, due to several restrictions, we are unable to ship to the following countries:

  1. Afghanistan
  2. American Samoa
  3. Belarus
  4. Brunei Darussalam
  5. Central African Republic
  6. The Democratic Republic of Congo
  7. Eritrea
  8. Guinea-bissau
  9. Iran
  10. Lebanon
  11. Libiya Arab Jamahriya
  12. Somalia
  13. Sudan
  14. Russian Federation
  15. Syrian Arab Republic
  16. Ukraine
  17. Venezuela