.NET 微服务和Docker容器

.NET 微服务:适用于容器化 .NET 应用的体系结构

容器和 Docker 简介

什么是 Docker?

Docker 术语

Docker 容器、映像和注册表

为 Docker 容器选择 .NET Core 还是 .NET Framework

通用指南

何时为 Docker 容器选择 .NET Core

何时为 Docker 容器选择 .NET Framework

决策表:用于 Docker 的 .NET Framework

使用 .NET 容器时定位的操作系统

官方 .NET Docker 映像

构建容器化微服务应用

容器化整体式应用

Docker 应用中的状态和数据

面向服务的体系结构

微服务体系结构

每个微服务的数据主权

逻辑体系结构与物理体系结构

分布式数据管理挑战和解决方案

标识每个微服务的域模型边界

微服务之间的通信

基于消息的异步通信

创建、改进和版本控制微服务 API 及协定

微服务可寻址性和服务注册表

根据微服务创建复合 UI,包括多个微服务生成的可视 UI 形状和布局

微服务中的复原和高可用性

安排微服务和多容器应用的业务流程,以实现高可伸缩性和高可用性

使用 Azure Service Fabric

Docker 应用开发流程

Docker 应用开发工作流

在 Linux 或 Windows Nano Server 主机上部署单容器 .NET Core Web 应用

将旧版整体式 .NET Framework 应用迁移到 Windows 容器

设计和开发多容器化微服务 .NET 应用

设计面向微服务的应用

创建简单的数据驱动 CRUD 微服务

使用 docker-compose.yml 定义多容器应用

使用作为容器运行的数据库服务器

在微服务(集成事件)之间实现基于事件的通信

使用 RabbitMQ 实现用于开发或测试环境的事件总线

订阅事件

测试 ASP.NET Core 服务和 Web 应用

使用 DDD 和 CQRS 模式降低微服务中的业务复杂性

在微服务中应用简化后的 CQRS 和 DDD 模式

在 eShopOnContainers 的 DDD 微服务中应用 CQRS 和 CQS 方法

在 CQRS 微服务中实现读取/查询

设计面向 DDD 的微服务

设计微服务域模型

使用 .NET Core 实现微服务域模型

Seedwork(适用于域模型的可重用基类和接口)

实现值对象

使用枚举类(而不是枚举类型)

在域模型层中设计验证

客户端验证(表示层中的验证)

域事件:设计和实现

设计基础结构持久性层

使用 Entity Framework Core 实现基础结构持久性层

将 NoSQL 数据库用作持久性基础结构

设计微服务应用层和 Web API

使用 Web API 实现微服务应用层

实现复原应用

处理部分失败错误

部分失败错误的处理策略

实现使用指数退避算法的重试

实现复原 Entity Framework Core SQL 连接

实现使用指数退避算法的自定义 HTTP 调用重试

使用 Polly 实现使用指数退避算法的 HTTP 调用重试

实现断路器模式

运行状况监视

保护 .NET 微服务和 Web 应用

关于 .NET 微服务和 Web 应用中的授权

在开发过程中安全地存储应用机密

在生产时使用 Azure Key Vault 保护机密

关键结论

相关的微服务和基于容器的参考应用:eShopOnContainers

eShopOnContainers 是开源的应用

GitHub:https://github.com/dotnet-architecture/eShopOnContainers

示例应用程序包括以下后端服务:

?    An identity microservice, which uses ASP.NET Core Identity and IdentityServer4.

?    A catalog microservice, which is a data-driven, create, read, update, delete (CRUD) service that consumes an SQL Server database using EntityFramework Core.

?    An ordering microservice, which is a domain-driven service that implements domain driven design patterns.

?    A basket microservice, which is a data-driven CRUD service that uses Redis Cache

?    A Marketing and Location microservices as example of No-SQL databases (MongoDB and CosmosDB).

?    An MVC watchdogs web app to query and show info from the HealthChecks (not shown in the above architecture diagram).

这些后端服务使用ASP.NET Web API实现为微服务器,并在单个Docker主机中部署为唯一容器。然后,客户端应用程序通过表示状态转移(REST)Web界面与后端服务进行通信。

微服务器还通过基于在RabbitMQ上实现的事件总线的异步消息进行通信,但事件总线也可以基于任何其他代理或服务总线,如Azure Service Bus,NServiceBus,MassTransit等。

此外,示例应用程序附带三个客户端应用程序:

?使用ASP.NET Core开发的MVC应用程序。

?使用Angular 2和Typescript开发的单页应用程序(SPA)。

?用Xamarin.Forms开发的跨平台移动应用程序。

博客介绍:https://blogs.msdn.microsoft.com/dotnet/2017/08/02/microservices-and-docker-containers-architecture-patterns-and-development-guidance/

电子书文档地址:https://docs.microsoft.com/zh-cn/dotnet/standard/microservices-architecture/

电子书PDF下载:http://aka.ms/MicroservicesEbook

.NET应用程序架构中心:https://www.microsoft.com/net/learn/architecture

如果你觉得本文对你有帮助,请点击“推荐”,谢谢。

时间: 2024-08-29 11:02:56

.NET 微服务和Docker容器的相关文章

微服务与Docker介绍

什么是微服务 微服务应用的一个最大的优点是,它们往往比传统的应用程序更有效地利用计算资源.这是因为它们通过扩展组件来处理功能瓶颈问题.这样一来,开发人员只需要为额外的组件部署计算资源,而不需要部署一个完整的应用程序的全新迭代.最终的结果是有更多的资源可以提供给其它任务. ? 一种软件架构模式 ? 复杂应用解耦为小而众的服务 ? 各服务精而专 ? 服务间通信通过API完成 微服务应用程序的另一个好处是,它们更快且更容易更新.当开发者对一个传统的单体应用程序进行变更时,他们必须做详细的QA测试,以确

微服务SpringCloud+Docker入门到高级实战

第一章 课程介绍和学习路线 1.微服务架构SpringCloud课程介绍简介:课程介绍和课程大纲讲解,讲课风格和重点内容理解技巧2.技术选型和学后水平简介:课程所需基础和技术选型讲解,学完课程可以到达怎样的程度, 第二章 架构演进和分布式系统基础知识 1.传统架构演进到分布式架构简介:讲解单机应用和分布式应用架构演进基础知识 (画图)2.微服务核心基础讲解简介:讲解微服务核心知识 :网关.服务发现注册.配置中心.链路追踪.负载均衡器.熔断3.常见的微服务框架简介:讲解常用的微服务框架4.微服务下

微服务与K8S容器云平台架构

微服务与K8S容器云平台架构 微服务与12要素 网络 日志收集 服务网关 服务注册 服务治理- java agent 监控 今天先到这儿,希望对技术领导力, 企业管理,系统架构设计与评估,团队管理, 项目管理, 产品管理,团队建设 有参考作用 , 您可能感兴趣的文章: 领导人怎样带领好团队构建创业公司突击小团队国际化环境下系统架构演化微服务架构设计视频直播平台的系统架构演化微服务与Docker介绍Docker与CI持续集成/CD互联网电商购物车架构演变案例互联网业务场景下消息队列架构互联网高效研

小D课堂 - 新版本微服务springcloud+Docker教程_汇总

小D课堂 - 新版本微服务springcloud+Docker教程_1_01课程简介 小D课堂 - 新版本微服务springcloud+Docker教程_1_02技术选型 小D课堂 - 新版本微服务springcloud+Docker教程_2_01传统架构演进到分布式架构 原文地址:https://www.cnblogs.com/wangjunwei/p/11434371.html

微服务SpringCloud+Docker入门到高级实战(教程详情)

第一章 课程介绍和学习路线 1.微服务架构SpringCloud课程介绍 简介:课程介绍和课程大纲讲解,讲课风格和重点内容理解技巧 2.技术选型和学后水平 简介:课程所需基础和技术选型讲解,学完课程可以到达怎样的程度, 1.IDEA JDK8 Maven SpringBoot基础 Linux 2.理解掌握并开发SpringCloud里面主流架构和组件的基础使用,还有部分源码原理的理解 3.掌握学习的技巧和解决问题的思路 第二章 架构演进和分布式系统基础知识 1.传统架构演进到分布式架构 简介:讲

微服务SpringCloud+Docker入门到高级实战(目录)

第一章 课程介绍和学习路线 1.微服务架构SpringCloud课程介绍 简介:课程介绍和课程大纲讲解,讲课风格和重点内容理解技巧2.技术选型和学后水平 简介:课程所需基础和技术选型讲解,学完课程可以到达怎样的程度, 第二章 架构演进和分布式系统基础知识 1.传统架构演进到分布式架构 简介:讲解单机应用和分布式应用架构演进基础知识 (画图)2.微服务核心基础讲解 简介:讲解微服务核心知识 :网关.服务发现注册.配置中心.链路追踪.负载均衡器.熔断3.常见的微服务框架 简介:讲解常用的微服务框架4

创建支持ssh服务的docker容器和镜像

http://www.kongxx.info/blog/?p=57 1. 这里使用的centos作为容器,所以首先下载centos的imagessudo docker pull centos 2. 下载后运行一个centos的容器,这里使用centos6作为我测试的容器sudo docker run --name=centos-ssh -i -t centos:centos6 /bin/bash 3. 安装openssh-server服务软件包yum install openssh-server

微服务 SpringCloud + docker

最近看到微服务很火,也是未来的趋势,所以就去学习下 好,接下来我们来认识下spring cloud.一.什么是spring cloud?它的中文官网这样说: 微服务架构集大成者,云计算最佳业务实践. 百度百科这样说的: Spring Cloud是一系列框架的有序集合.它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发, 如服务发现注册.配置中心.消息总线.负载均衡.断路器.数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署. Spring Cloud

【微服务轻量化容器技术相关】同事分享的Docker学习汇总

还没时间去练习: Docker commands: docker images (list all image on this host) docker ps -a ( list all containers on this host) docker run -t -i centos6_oodee /bin/bash ( create a container with command) docker start 091a802729cd ( start one instance of the c