使用 .NET Core 实现微服务(带例子)

使用 .NET Core 实现微服务

使用 .NET Core 实现微服务架构涉及几个关键步骤,包括服务划分、API 网关、服务通信和容器化部署。下面是一个简化的示例,展示如何使用 .NET Core 实现一个基本的微服务架构。

步骤 1:创建独立的微服务

  1. 定义微服务

    每个微服务都是一个独立的 ASP.NET Core Web API 项目。例如,我们可以创建两个微服务:一个用户服务(UserService)和一个订单服务(OrderService)。

  2. 创建用户服务

    使用 .NET CLI 创建一个新的 ASP.NET Core Web API 项目:

    bash 复制代码
    dotnet new webapi -n UserService

    在 UserService 项目中定义一个简单的控制器:

    csharp 复制代码
    using Microsoft.AspNetCore.Mvc;
    
    namespace UserService.Controllers
    {
        [ApiController]
        [Route("[controller]")]
        public class UsersController : ControllerBase
        {
            [HttpGet("{id}")]
            public IActionResult GetUserById(int id)
            {
                return Ok(new { Id = id, Name = "John Doe" });
            }
        }
    }
  3. 创建订单服务

    同样地,创建一个订单服务(OrderService)项目:

    bash 复制代码
    dotnet new webapi -n OrderService

    在 OrderService 项目中定义一个简单的控制器:

    csharp 复制代码
    using Microsoft.AspNetCore.Mvc;
    
    namespace OrderService.Controllers
    {
        [ApiController]
        [Route("[controller]")]
        public class OrdersController : ControllerBase
        {
            [HttpGet("{id}")]
            public IActionResult GetOrderById(int id)
            {
                return Ok(new { Id = id, Product = "Laptop", Quantity = 1 });
            }
        }
    }

步骤 2:使用 API 网关

  1. 创建 API 网关

    使用 Ocelot 作为 API 网关。创建一个新的 ASP.NET Core 项目用于 API 网关:

    bash 复制代码
    dotnet new webapi -n ApiGateway

    添加 Ocelot 包:

    bash 复制代码
    dotnet add package Ocelot

    配置 Ocelot。在 appsettings.json 中定义路由配置:

    json 复制代码
    {
      "Routes": [
        {
          "DownstreamPathTemplate": "/users/{id}",
          "DownstreamScheme": "http",
          "DownstreamHostAndPorts": [
            {
              "Host": "localhost",
              "Port": 5001
            }
          ],
          "UpstreamPathTemplate": "/api/users/{id}",
          "UpstreamHttpMethod": [ "Get" ]
        },
        {
          "DownstreamPathTemplate": "/orders/{id}",
          "DownstreamScheme": "http",
          "DownstreamHostAndPorts": [
            {
              "Host": "localhost",
              "Port": 5002
            }
          ],
          "UpstreamPathTemplate": "/api/orders/{id}",
          "UpstreamHttpMethod": [ "Get" ]
        }
      ],
      "GlobalConfiguration": {
        "BaseUrl": "http://localhost:5000"
      }
    }
  2. 配置启动文件

    Startup.cs 中配置 Ocelot:

    csharp 复制代码
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddOcelot();
    }
    
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
    
        app.UseRouting();
        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllers();
        });
    
        app.UseOcelot().Wait();
    }

步骤 3:运行微服务和 API 网关

  1. 运行服务

    启动 UserService 和 OrderService,指定不同的端口:

    bash 复制代码
    dotnet run --project UserService --urls "http://localhost:5001"
    dotnet run --project OrderService --urls "http://localhost:5002"
  2. 运行 API 网关

    启动 ApiGateway 项目:

    bash 复制代码
    dotnet run --project ApiGateway --urls "http://localhost:5000"

步骤 4:测试微服务

使用浏览器或 Postman 访问以下 URL 测试微服务:

  • 获取用户信息:http://localhost:5000/api/users/1
  • 获取订单信息:http://localhost:5000/api/orders/1

结论

通过上述步骤,你可以创建和运行一个基本的微服务架构,其中每个微服务都是一个独立的 ASP.NET Core Web API 项目,API 网关使用 Ocelot 进行路由和负载均衡。根据具体需求,还可以添加更多的微服务、身份验证和授权机制、服务发现、监控等功能。

相关推荐
尘世中一位迷途小书童3 分钟前
版本管理实战:Changeset 工作流完全指南(含中英文对照)
前端·面试·架构
尘世中一位迷途小书童7 分钟前
VitePress 文档站点:打造专业级组件文档(含交互式示例)
前端·架构·前端框架
m0_6515939143 分钟前
Netty网络架构与Reactor模式深度解析
网络·架构
xrkhy4 小时前
微服务之SpringCloud Alibaba(注册中心Nacos)
spring cloud·微服务·架构
会开花的二叉树4 小时前
C++微服务 UserServer 设计与实现
开发语言·c++·微服务
虫小宝4 小时前
Java分布式架构下的电商返利APP技术选型与架构设计实践
java·分布式·架构
唐僧洗头爱飘柔95275 小时前
【SpringCloud(6)】Gateway路由网关;zuul路由;gateway实现原理和架构概念;gateway工作流程;静态转发配置
spring·spring cloud·架构·gateway·请求转发·服务降级·服务雪崩
来旺5 小时前
互联网大厂Java面试全解析及三轮问答专项
java·数据库·spring boot·安全·缓存·微服务·面试
白衣鸽子6 小时前
RPO 与 RTO:分布式系统容灾的双子星
后端·架构
Knight_AL6 小时前
Spring Boot 中使用自定义注解和 AOP 实现微服务日志记录(包含 URL、状态码和耗时信息)
linux·spring boot·微服务