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 RuntimeVS CodeIdentityServicetye run --watchAttach DebuggerAttach to processBreakpoint Hit开发者Tye RuntimeVS CodeIdentityService

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.pswp.cn/news/913763.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/913763.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue响应式原理一:认识响应式逻辑

核心思想&#xff1a;当数据发生变化时&#xff0c;依赖该数据的代码能够自动重新执行Vue中的应用&#xff1a;在data或ref/reactive中定义的数据&#xff0c;当数据变化时template会自动更新template的本质&#xff1a; 是render()函数, 用变化之后的数据重新执行render()函数…

Redis:分组与设备在 Redis 中缓存存储设计

一、缓存存储结构设计 分组与设备的映射关系&#xff08;使用 Set 结构&#xff09;&#xff1a; 键格式&#xff1a;采用 group:{groupId}:devices 的格式作为 Redis 中 Set 的键&#xff0c;例如 group:1:devices 就代表了分组 ID 为 1 的分组所关联的设备集合。值内容&#…

Leetcode 3605. Minimum Stability Factor of Array

Leetcode 3605. Minimum Stability Factor of Array 1. 解题思路2. 代码实现 题目链接&#xff1a;3605. Minimum Stability Factor of Array 1. 解题思路 这一题的核心思路是二分法&#xff0c;本质上就是我们给定一个常数kkk&#xff0c;然后考察是否存在一个构造使得能够…

编译安装的Mysql5.7报“Couldn‘t find MySQL server (mysqld_safe)“的原因 笔记250709

编译安装的Mysql5.7报"Couldn’t find MySQL server (mysqld_safe)"的原因 笔记250709 MySQL 的安装路径与配置文件&#xff08;如 my.cnf 或 mysql.server&#xff09;中指定的 basedir 不一致。 mysqld_safe 文件实际位置与系统查找路径不匹配&#xff08;常见于自…

在 Ubuntu 下配置 oh-my-posh —— 普通用户 + root 各自使用独立主题(共享可执行)

&#x1f9e9; 在 Ubuntu 下配置 oh-my-posh —— 普通用户 root 各自使用独立主题&#xff08;共享可执行&#xff09;✅ 目标说明普通用户 使用 tokyonight_storm 主题 root 用户 使用 1_shell 主题 共用全局路径下的 oh-my-posh 可执行文件 正确加载 Homebrew 到环境变量中…

Spring Boot 项目中的多数据源配置

关键词&#xff1a;Spring Boot、多数据源配置、MySQL、SQL Server、Oracle、动态切换 ✅ 摘要 在实际企业级开发中&#xff0c;一个 Spring Boot 项目可能需要连接多个数据库&#xff0c;比如 MySQL、SQL Server 和 Oracle。不同的业务模块可能依赖不同的数据源&#xff0c;这…

MATLAB/Simulink电机控制仿真代做 同步异步永磁直驱磁阻双馈无刷

以下是针对 MATLAB/Simulink 电机控制仿真 的系统性解决方案&#xff0c;涵盖 同步电机、异步电机、永磁电机、直驱电机、磁阻电机、双馈电机、无刷直流电机&#xff08;BLDC&#xff09; 的建模与控制策略实现&#xff0c;支持代做服务的技术细节和代码示例。一、电机建模与仿…

限流算法深度探索:从理论到实践的生产级避坑指南

凌晨3点&#xff0c;监控警报刺耳地尖叫着。我盯着屏幕上垂直下跌的服务可用性曲线&#xff0c;意识到那个被忽视的限流配置项终于引爆了——每秒1000次的支付请求正像洪水般冲垮我们的系统。这次事故让我深刻理解&#xff1a;限流不是可选项&#xff0c;而是分布式系统的生存法…

企业级后台管理系统的困境与飞算 JavaAI 的破局之道

企业级后台管理系统如 CRM&#xff08;客户关系管理系统&#xff09;、ERP&#xff08;企业资源计划系统&#xff09;已成为支撑企业高效运转的核心骨架。它们如同企业的 “神经中枢”&#xff0c;串联起客户数据、财务信息、供应链流程等关键环节&#xff0c;为决策制定、业务…

快速上手百宝箱搭建知识闯关游戏助手

引言&#xff1a;让学习更有趣&#xff0c;AI 赋能知识闯关新体验 1.在信息爆炸的时代&#xff0c;传统的填鸭式教学方式已难以满足现代用户对高效、个性化和趣味化学习的需求。越来越多的学习者倾向于通过互动性强、参与感十足的方式获取知识。在此背景下&#xff0c;游戏化学…

【YOLOv11-目标检测】目标检测数据格式(官方说明)

原文链接&#xff1a; https://docs.ultralytics.com/datasets/detect/ 写在前面 训练一个鲁棒且准确的目标检测模型需要一个全面的数据集。本文介绍&#xff1a;与Ultralytics YOLO模型兼容的各种数据集格式&#xff0c;并深入解析了它们的结构、使用方法以及如何在不同的格…

yolo8实现目标检测

✅步骤一&#xff1a;安装 PyTorch&#xff08;M1 专用&#xff09;# 推荐使用官方 MPS 后端&#xff08;Apple Metal 加速&#xff09; pip install torch torchvision torchaudio确认是否使用了 Apple MPS&#xff1a;import torch print(torch.backends.mps.is_available()…

安全管理协议(SMP):配对流程、密钥生成与防中间人攻击——蓝牙面试核心考点精解

一、SMP 核心知识点高频考点解析1.1 SMP 在蓝牙安全体系中的定位考点&#xff1a;SMP 的功能与协议栈位置解析&#xff1a; SMP&#xff08;Security Manager Protocol&#xff0c;安全管理协议&#xff09;是蓝牙核心规范中负责设备配对、密钥生成与安全连接的关键协议&#x…

U盘实现——U 盘类特殊命令

文章目录 U 盘类特殊命令U 盘的命令封包命令阶段数据阶段状态阶段get max luninquiry(0x12)read format capacities(0x23)read capacity(0x25)mode sense(0x1a)test unit ready(0x00)read(10) 0x28write(10) 0x2aU 盘类特殊命令 U 盘的命令封包 命令阶段 命令阶段主要由主机通…

深度帖:浏览器的事件循环与JS异步

一、浏览器进程 早期的浏览器是单进程的&#xff0c;所有功能杂糅在一个进程中&#xff1b;现在的浏览器是多进程的&#xff0c;包含浏览器进程、网络进程、渲染进程等等&#xff0c;每个进程负责的工作不同。浏览器进程&#xff1a;负责界面显示&#xff08;地址栏、书签、历史…

Linux网络:UDP socket创建流程与简单通信

本文介绍 UDP 服务端与客户端 的创建流程&#xff0c;和相关的函数接口 核心流程 创建 socket → socket()填写服务器地址信息 → sockaddr_in 结构体绑定地址和端口 → bind()接收并响应客户端数据 → recvfrom() / sendto()socket() #include<sys/so…

windows内核研究(系统调用 1)

WindowsAPI函数的调用过程什么是WindowsApi&#xff1f;Windows API&#xff08;Application Programming Interface&#xff0c;应用程序编程接口&#xff09;是微软为Windows操作系统提供的一套系统级编程接口&#xff0c;允许开发者与操作系统内核、硬件、系统服务等进行交互…

【前端】异步任务风控验证与轮询机制技术方案(通用笔记版)

一、背景场景 在某类生成任务中&#xff0c;例如用户点击“执行任务”按钮后触发一个较耗时的后端操作&#xff08;如生成报告、渲染图像、转码视频等&#xff09;&#xff0c;由于其调用了模型、渲染服务或需要较长处理时间&#xff0c;为了防止接口被频繁恶意调用&#xff0c…

Vim 编辑器常用操作详解(新手快速上手指南)

&#x1f4bb; Vim 编辑器常用操作详解&#xff08;新手快速上手指南&#xff09;作者&#xff1a;Lixin 日期&#xff1a;2025-07-09 学习内容&#xff1a;Vim 编辑器基础 常用快捷键 Xshell/Xftp连接 Linux基本操作 学习目标&#xff1a;掌握 Vim 的三种常用模式切换与基本…

OpenGL 生成深度图与点云

文章目录 一、简介二、实现代码三、实现效果一、简介 这里基于OpenGL实现对一个Mesh对象深度图的获取,思路其实很简单,直接通过glReadPixels函数获取整个OpenGL中的深度缓冲数据即可;那么反过来我们如果有了这个深度图之后,也可以基于每个像素点的深度值,反算出图像中的深…