当前位置: 首页 > news >正文

ABP VNext + Tye:本地微服务编排与调试

ABP VNext + Tye:本地微服务编排与调试 🚀


📚 目录

  • ABP VNext + Tye:本地微服务编排与调试 🚀
    • TL;DR ✨
    • 一、环境与依赖 🛠️
    • 二、核心配置详解 🚀
      • 1. 主配置 `tye.yaml`
    • 三、多环境文件 🌱🌳
      • `tye.development.yaml`
      • `tye.production.yaml`
    • 四、依赖容器定义 🐳
    • 五、ABP VNext 集成 🔌
      • 1. NuGet 包
      • 2. `appsettings.json`
      • 3. 分布式缓存 & 锁 🔒
      • 4. RabbitMQ & CAP 🐰
      • 5. 全链路追踪 🕵️
    • 六、一键启动 & 验证 ⚡
    • 七、流程图 📊
      • 1. 配置加载与启动
      • 2. 服务依赖关系
    • 八、断点调试 🎯
      • VS Code Attach
      • 调试序列图
    • 九、进阶与安全 🛠️🔒


TL;DR ✨

  • 🚀 一键编排:ABP VNext 微服务 + SQL Server、Redis、RabbitMQ、Jaeger,tye run --env … 即可全量本地启动
  • 💪 高可用 & 性能:双保险健康检查、资源 requests/limits、多副本、死信队列与自动重试
  • 🔍 全链路可观测:HTTP/gRPC/EF Core Trace → Jaeger UI → Tye Dashboard

一、环境与依赖 🛠️

  1. 必备工具

    • .NET 6+ SDK

    • ABP VNext 6.x(Volo.Abp.* 系列)

    • Microsoft Tye CLI

      dotnet tool install -g Microsoft.Tye --version "0.12.0-alpha.*"
      
    • Docker Desktop(含 SQL Server、Redis、RabbitMQ、Jaeger 镜像)

  2. 容器镜像

    • SQL Server 2022:mcr.microsoft.com/mssql/server:2022-latest
    • Redis 7:redis:7
    • RabbitMQ 3-management:rabbitmq:3-management
    • Jaeger All-in-One:jaegertracing/all-in-one:1.49
  3. 项目结构

    abp-tye-demo/
    ├─ services/
    │   ├─ IdentityService/
    │   ├─ OrderService/
    │   └─ ProductService/
    ├─ tye.yaml
    ├─ tye.development.yaml
    ├─ tye.production.yaml
    ├─ docker-compose.override.yml
    └─ README.md
    

二、核心配置详解 🚀

1. 主配置 tye.yaml

name: abp-tye-demosecrets:- name: Jwt__Keyservices:# —— 外部依赖 —— - name: sqldockerCompose:file: docker-compose.override.yml- name: redisdockerCompose:file: docker-compose.override.yml- name: rabbitmqdockerCompose:file: docker-compose.override.yml- name: jaegerdockerCompose:file: docker-compose.override.yml# —— ABP 微服务 —— - name: identityproject: services/IdentityService/IdentityService.csprojbindings:- port: 5001env:ConnectionStrings__Default: "Server=sql;User Id=sa;Password=Your_password123;"Redis__Configuration: "redis:6379"RabbitMQ__HostName: "rabbitmq"RabbitMQ__User: "tye"RabbitMQ__Pass: "tyePass123"Jaeger__AgentHost: "jaeger"Jaeger__AgentPort: "6831"Jwt__Key: "Jwt__Key"- name: orderproject: services/OrderService/OrderService.csprojbindings:- port: 5002env:ConnectionStrings__Default: "Server=sql;User Id=sa;Password=Your_password123;"Redis__Configuration: "redis:6379"RabbitMQ__HostName: "rabbitmq"RabbitMQ__User: "tye"RabbitMQ__Pass: "tyePass123"Jaeger__AgentHost: "jaeger"Jaeger__AgentPort: "6831"- name: productproject: services/ProductService/ProductService.csprojbindings:- port: 5003env:ConnectionStrings__Default: "Server=sql;User Id=sa;Password=Your_password123;"Redis__Configuration: "redis:6379"RabbitMQ__HostName: "rabbitmq"RabbitMQ__User: "tye"RabbitMQ__Pass: "tyePass123"Jaeger__AgentHost: "jaeger"Jaeger__AgentPort: "6831"
  • 多环境自动合并tye run --env development|production 会加载对应文件
  • Secrets:通过 tye secret set Jwt__Key ... 注入
  • RabbitMQ 用户guest 仅限本地,容器间需自定义用户

三、多环境文件 🌱🌳

tye.development.yaml

services:- name: identityreplicas: 1- name: orderreplicas: 1- name: productreplicas: 1

tye.production.yaml

services:- name: identityreplicas: 2resources:requests:cpu: "0.25"memory: "256Mi"limits:cpu: "0.5"memory: "512Mi"- name: orderreplicas: 2resources:requests:cpu: "0.25"memory: "256Mi"limits:cpu: "0.5"memory: "512Mi"- name: productreplicas: 2resources:requests:cpu: "0.25"memory: "256Mi"limits:cpu: "0.5"memory: "512Mi"

四、依赖容器定义 🐳

version: '3.4'
services:sql:image: mcr.microsoft.com/mssql/server:2022-latestenvironment:SA_PASSWORD: "Your_password123"ACCEPT_EULA: "Y"ports:- "1433:1433"volumes:- ./mssql-data:/var/opt/mssqlhealthcheck:test: ["CMD", "sh", "-c", "if nc -z localhost 1433; then exit 0; else exit 1; fi"]interval: 10sretries: 5redis:image: redis:7ports:- "6379:6379"healthcheck:test: ["CMD", "redis-cli", "ping"]interval: 10sretries: 5rabbitmq:image: rabbitmq:3-managementenvironment:RABBITMQ_DEFAULT_USER: "tye"RABBITMQ_DEFAULT_PASS: "tyePass123"ports:- "5672:5672"    # AMQP- "15672:15672"  # Management UIhealthcheck:test: ["CMD", "rabbitmq-diagnostics", "ping"]interval: 10sretries: 5jaeger:image: jaegertracing/all-in-one:1.49ports:- "16686:16686"     # Jaeger UI- "6831:6831/udp"   # Trace 数据
  • 数据持久化:SQL Server volume
  • 网络说明:Linux 可选 network: host

五、ABP VNext 集成 🔌

1. NuGet 包

<PackageReference Include="Volo.Abp.AspNetCore" Version="6.*" />
<PackageReference Include="Volo.Abp.DistributedLocking.Redis" Version="6.*" />
<PackageReference Include="Volo.Abp.EventBus.CAP" Version="6.*" />

2. appsettings.json

{"ConnectionStrings": {"Default": "Server=sql;User Id=sa;Password=Your_password123;"},"Redis": {"Configuration": "redis:6379"},"RabbitMQ": {"HostName": "rabbitmq","Port": 5672,"User": "tye","Pass": "tyePass123"},"Jaeger": {"AgentHost": "jaeger","AgentPort": 6831},"Jwt": {"Key": ""}
}

3. 分布式缓存 & 锁 🔒

builder.Services.AddStackExchangeRedisCache(options =>{options.Configuration = builder.Configuration["Redis:Configuration"];}).AddAbpDistributedLock(sp =>sp.AddRedisLock(builder.Configuration["Redis:Configuration"]));

4. RabbitMQ & CAP 🐰

builder.Services.AddCap(options =>
{options.UseRabbitMQ(cfg =>{cfg.HostName = builder.Configuration["RabbitMQ:HostName"];cfg.Port = int.Parse(builder.Configuration["RabbitMQ:Port"]);cfg.UserName = builder.Configuration["RabbitMQ:User"];cfg.Password = builder.Configuration["RabbitMQ:Pass"];});options.UseDashboard();options.FailedRetryCount = 5;
});// 事件订阅示例
public class OrderCreatedConsumer : ICapSubscribe
{[CapSubscribe("order.created")]public Task Handle(OrderCreatedEvent evt) => /*...*/;
}

5. 全链路追踪 🕵️

builder.Services.AddOpenTelemetryTracing(tp =>
{tp.AddAspNetCoreInstrumentation().AddHttpClientInstrumentation().AddGrpcClientInstrumentation().AddEntityFrameworkCoreInstrumentation().AddJaegerExporter(opts =>{opts.AgentHost = builder.Configuration["Jaeger:AgentHost"];opts.AgentPort = int.Parse(builder.Configuration["Jaeger:AgentPort"]);});
});

六、一键启动 & 验证 ⚡

# 注入 Secret
tye secret set Jwt__Key --value "YourSuperSecretKey"# 启动服务
tye run --env production --watch
  • 验证副本 & 资源tye describe

  • 访问监控

    功能地址
    Tye Dashboardhttp://localhost:8000
    RabbitMQ UIhttp://localhost:15672
    Jaeger UIhttp://localhost:16686

七、流程图 📊

1. 配置加载与启动

合并配置
环境变量
自动加载 tye.production.yaml
合并到 tye.yaml
tye run --env production
Tye Runtime 启动
服务列表
sql, redis, rabbitmq, jaeger
identity, order, product

2. 服务依赖关系

Services
Containers
Trace
Trace
Trace
Metrics & Logs
Metrics & Logs
Metrics & Logs
IdentityService
5001
OrderService
5002
ProductService
5003
SQL Server
1433
Redis
6379
RabbitMQ
5672
Jaeger
6831/UDP
Tye Dashboard

八、断点调试 🎯

VS Code Attach

{"version": "0.2.0","configurations": [{"name": "Attach to Tye IdentityService","type": "coreclr","request": "attach","processName": "dotnet","justMyCode": false}]
}

调试序列图

开发者 Tye Runtime VS Code IdentityService tye run --watch Attach Debugger Attach to process Breakpoint Hit 开发者 Tye Runtime VS Code IdentityService

Tip:遇到 IIS Express 冲突,切换至 “Project” 启动或在 launchSettings.json 指定 --urls http://*:5001


九、进阶与安全 🛠️🔒

  1. 自定义 Dockerfile

    - name: custom-servicecontainer:dockerFile: services/Custom/Dockerfileimage: myorg/custom:latest
    
  2. 公网隧道

    tye proxy identity --bind 5001
    

    ⚠️ 仅限测试,生产请结合 API Gateway/认证。

  3. 网络模式

    • Linux 可选 network: host
    • 跨宿主机访问时可自定义 Docker 网络

http://www.lryc.cn/news/581671.html

相关文章:

  • 基于udev规则固定相机名称
  • [netty5: WebSocketServerHandshaker WebSocketServerHandshakerFactory]-源码分析
  • 桥梁桥拱巡检机器人cad+【4张】设计说明书+绛重+三维图
  • 力扣 hot100 Day36
  • webUI平替应用,安装简单,功能齐全
  • LeetCode 75. 颜色分类(荷兰国旗问题)
  • 服务端向客户端主动推送数据的几种方法(Spring Boot 环境)
  • 11.进程间通信
  • VSCode+arm-none-eabi-gcc交叉编译+CMake构建+OpenOCD(基于Raspberry Pico RP2040)
  • 2.线性神经网络--Softmax回归
  • 算法分析与设计实验1:实现两路合并排序和折半插入排序
  • 3.8 java连接数据库
  • Vue2 day07
  • 工业相机和镜头
  • 基于Java+SpringBoot的医院信息管理系统
  • ARM 学习笔记(一)
  • 文心开源大模型ERNIE-4.5-0.3B-Paddle私有化部署保姆级教程及技术架构探索
  • 【学习笔记】4.1 什么是 LLM
  • 编程语言艺术:C语言中的属性attribute笔记总结
  • 程序员在线接单
  • 浅谈漏洞扫描与工具
  • 大型语言模型中的自动化思维链提示
  • 【数据分析】R语言多源数据的基线特征汇总
  • 玄机——第三章 权限维持-linux权限维持-隐藏练习
  • Dify+Ollama+QwQ:3步本地部署,开启AI搜索新篇章
  • 实现Spring MVC登录验证与拦截器保护:从原理到实战
  • 【机器学习深度学习】 如何解决“宏平均偏低 / 小类识别差”的问题?
  • HRDNet: High-resolution Detection Network for Small Objects论文阅读
  • mac中创建 .command 文件,执行node服务
  • Omi录屏专家 Screen Recorder by Omi 屏幕录制Mac