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
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
Pragmatic Microservices with C# and Azure

You're reading from   Pragmatic Microservices with C# and Azure Build, deploy, and scale microservices efficiently to meet modern software demands

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

Table of Contents (23) Chapters Close

Preface 1. Part 1: Creating Microservices with .NET
2. Chapter 1: Introduction to .NET Aspire and Microservices FREE CHAPTER 3. Chapter 2: Minimal APIs – Creating REST Services 4. Chapter 3: Writing Data to Relational and NoSQL Databases 5. Chapter 4: Creating Libraries for Client Applications 6. Part 2: Hosting and Deploying
7. Chapter 5: Containerization of Microservices 8. Chapter 6: Microsoft Azure for Hosting Applications 9. Chapter 7: Flexible Configurations 10. Chapter 8: CI/CD – Publishing with GitHub Actions 11. Chapter 9: Authentication and Authorization with Services and Clients 12. Part 3: Troubleshooting and Scaling
13. Chapter 10: All About Testing the Solution 14. Chapter 11: Logging and Monitoring 15. Chapter 12: Scaling Services 16. Part 4: More communication options
17. Chapter 13: Real-Time Messaging with SignalR 18. Chapter 14: gRPC for Binary Communication 19. Chapter 15: Asynchronous Communication with Messages and Events 20. Chapter 16: Running Applications On-Premises and in the Cloud 21. Index 22. Other Books You May Enjoy

What this book covers

Chapter 1, Introduction to .NET Aspire and Microservices, gives you an introduction to .NET Aspire, as well as tools and libraries that can be of great help when creating microservices. You’ll start an initial .NET Aspire project, and we will look at what it consists of and the parts of .NET Aspire you can take advantage of. You’ll see the services that the Codebreaker application (this is the solution we are going to build in all the chapters of the book) is made up of and learn about the services that are used with Microsoft Azure.

Chapter 2, Minimal APIs – Creating REST Services, acts as the kick-off for creating the Codebreaker application. You will learn how to use the ASP.NET Core minimal API technology to efficiently create REST services, use OpenAPI to describe the services, and test the services with HTTP files.

Chapter 3, Writing Data to Relational and NoSQL Databases, uses just the in-memory storage in Chapter 2 and adds database storage using Azure SQL and Azure Cosmos DB, comparing relational to non-relational databases and using EF Core with both variants.

Chapter 4, Creating Libraries for Client Applications, adds client libraries to access the services, with one variant using an HTTP client factory and another making use of Kiota to automatically generate code for the client.

Chapter 5, Containerization of Microservices, dives into all the important concepts of Docker and how to create Docker images from the services created so far. You will learn the concepts of Docker before using the .NET CLI to create Docker images. A .NET native AOT version of a service will be created that allows for creating Docker images without a .NET runtime, just native code.

Chapter 6, Microsoft Azure for Hosting Applications, as Docker images have been created in the previous chapter, will now cover how to publish the application to an Azure Container Apps environment. Before that, important concepts of Azure are covered. Then, Azure resources will be created with the help of the Azure Developer CLI and .NET Aspire.

Chapter 7, Flexible Configurations, dives into the .NET configuration. You’ll understand configuration providers with .NET, learn how configuration applies to the app model of .NET Aspire, add configurations and secrets with Azure Container Apps, and integrate Azure App Configuration and Azure Key Vault. For easier access without the need to store secrets, Azure managed identities are covered here as well.

Chapter 8, CI/CD – Publishing with GitHub Actions, builds on the fact that continuous integration and continuous delivery are important aspects of a microservices solution. This chapter covers how to automatically build and test applications with GitHub actions and how to automatically update solutions running on Microsoft Azure. To support modern deployment patterns, feature flags available with Azure App Configuration are integrated in this chapter.

Chapter 9, Authentication and Authorization with Service and Clients, covers two versions to authenticate and authorize applications and users: integration of Azure Active Directory B2C for the cloud version of the Codebreaker solution and ASP.NET Core identities for the on-premises solution. To avoid dealing with authentication with every service, a gateway using YARP is created.

Chapter 10, All About Testing the Solution, states that no change should break the application and errors should be detected as early as possible. In this chapter, you will learn about creating unit tests, integration tests with .NET Aspire (which makes testing a lot simpler), and using Playwright for end-to-end tests.

Chapter 11, Logging and Monitoring, delves into what is going on in the Codebreaker application. Memory leaks should be detected early. During development, we should look into the details of how the application communicates. This chapter covers efficient high-performance logging, writing custom metrics data, and distributed tracing – including the coverage of OpenTelemetry and how this integrates with .NET Aspire. In this chapter, we use Prometheus and Grafana for the on-premises solution and Azure Application Insights and Azure Log Analytics with the cloud.

Chapter 12, Scaling Services, delves into scaling services, which is one of the important reasons for using a microservices architecture. Using Azure Load Testing, we create a huge load on the main service of the application and find out what the bottlenecks are, decide between scaling up and scaling out, and add caching to increase performance using Redis.

Chapter 13, Real-Time Messaging with SignalR, covers informing clients in real time using SignalR. Using a REST API, a SignalR hub is invoked, passing real-time information about completed games, and the SignalR hub passes on this information to a group of clients. Azure SignalR Service is used to reduce the load from the services.

Chapter 14, gRPC for Binary Communication, increases the performance by changing communication to gRPC with service-to-service communication. You will learn how to create a Protocol Buffers definition, implement services and clients using this binary platform-independent communication, and how .NET service discovery and .NET Aspire can be used with gRPC.

Chapter 15, Asynchronous Communication with Messages and Events, deals with the fact that often answers are not required immediately after the request is sent – message queues and events come into play. Here, Azure message queues, Azure Event Hubs, and Kafka for an on-premises environment come into play to be used.

Chapter 16, Running Applications On-Premises and in the Cloud, discusses what’s needed in a production environment when running on Azure, what the differences between production and development environments are, and how the Codebreaker application fulfills requirements relating to scalability, reliability, and security. Up to this chapter, the application was running either on the local development system or within an Azure Container Apps environment. In this chapter, the application is deployed to Azure Kubernetes Service and can be deployed in a similar way to an on-premises Kubernetes cluster using the Aspir8 tool.

lock icon The rest of the chapter is locked
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
Banner background image