In our recent let’s study together. We received some great questions during the microservices event at NET. We’ve answered a lot of questions from the floor, but we want to continue answering some of the hottest questions that came up during the conference. If you missed the live broadcast, don’t worry, because you can watch it on demand.

Watch the video

As we extend these services, how do we extend the databases associated with these services?

There are well-defined patterns and best practices that can improve performance and scale the database. To learn how to partition data to improve scalability, reduce, and optimize performance, see horizontal, vertical, and Functional Data partitioning. For an in-depth look at the scalability of microservices, distributed data, why every microservice has a database, and the choice between a relational database and a NoSQL database, see our guide to building cloud-native.NET applications for Azure or download our free ebook.

Do we need a new database for each microservice, or can microservices share the same database instance?

The team’s autonomy to use microservices is an important benefit of building cloud-native applications. To give the team the flexibility to roll out updates, security patches, and bug fixes in production without breaking other microservices, it is best to use a separate database instance. The native cloud application architecture is inspired by the well-known 12-factor application methodology. One of these factors, “support services,” states that secondary resources such as data stores, caches, message brokers, and so on should be exposed through an addressable URL. Cloud providers offer a rich variety of hosting support services. We recommend examining the database options available in the cloud rather than owning and maintaining the database yourself.

Can a single Web API communicate with microservices?

Yes. Monolithic applications can communicate with microservices if their endpoints are reachable in the infrastructure or securely accessed using common endpoints. Microservices and their data can be consumed synchronously through their endpoints or asynchronously through messaging, such as an event bus. As part of modern technology, we recommend killing patterns that facilitate gradual migration of older systems. As part of the solution, you need to create a facade that blocks requests. Facade routes these requests to the old application or to the new service. For more information on microservices communication and modern technologies, see the.NET Architecture Guide.

If microservices are loosely coupled and independently deployed, how do they communicate with each other? How do I synchronize data between microservices?

That’s a good question. This is explained in detail in two chapters of the book Building Cloud-native.NET Applications for Azure. These links will help you:

  • Native cloud communication mode or download free e-books.
  • Manage data in distributed applications.
  • You can also download a free ebook on the microservices Architecture Guide, which covers patterns such as DDD, CQRS, event sources, and more.

Do microservices need to use containers?

There’s no need. However, using containers also has its advantages. Microservices, often referred to as microservices architecture, are design guidelines and best practices. It helps you decompose your application into smaller services defined by specific business boundaries that are managed independently by smaller teams. A container combines an application and its configuration and dependencies into a single, independent deployable unit. Containers are great for binding and deploying standalone microservices. You can see the benefits by writing your first microservice endpoint and containerizing it.

More microservices resources

Are you looking for more microservices and on-premises cloud resources for.NET development? Stay tuned to the Microsoft blog and official documentation. If you have any questions, please come to the Microsoft Q&A forum: docs.microsoft.com/en-us/answe… .