首页
/ 在FullStackHero .NET Starter Kit中不使用Docker的运行方案

在FullStackHero .NET Starter Kit中不使用Docker的运行方案

2025-06-06 20:55:56作者:薛曦旖Francesca

FullStackHero .NET Starter Kit是一个功能强大的.NET全栈开发框架,它默认使用Docker容器化部署方案。然而在实际开发中,开发者可能希望采用非Docker化的传统运行方式。本文将详细介绍如何在该项目中实现非Docker化的运行方案。

项目架构分析

FullStackHero .NET Starter Kit主要由三个核心组件构成:

  1. ASPIRE Dashboard - 用于项目监控和管理
  2. Web API - 提供后端服务
  3. Blazor应用 - 前端用户界面

其中ASPIRE Dashboard组件必须依赖Docker环境运行,而Web API和Blazor应用则可以脱离Docker独立运行。

非Docker化运行方案

方案一:仅运行Web API和Blazor应用

这是最简单的非Docker化方案,适用于大多数开发场景:

  1. 通过Visual Studio或dotnet CLI直接启动Web API项目
  2. 单独运行Blazor前端项目
  3. 配置两者之间的通信(通常通过修改appsettings.json中的API地址)

方案二:使用IIS Express或Kestrel

对于需要完整本地开发环境的场景:

  1. 配置IIS Express或直接使用Kestrel作为Web服务器
  2. 设置多个启动项目(同时启动API和Blazor)
  3. 配置开发环境变量和连接字符串

配置调整要点

脱离Docker环境后,需要特别注意以下配置项的调整:

  1. 数据库连接字符串 - 从Docker容器地址改为本地或远程数据库地址
  2. 跨域设置(CORS) - 确保API允许Blazor应用的访问
  3. 环境变量 - 将Docker特有的环境变量改为传统配置方式
  4. 日志配置 - 调整日志输出路径和方式

开发环境建议

对于不使用Docker的开发环境,推荐采用以下工具链组合:

  1. 使用SQL Server LocalDB或完整SQL Server实例替代Docker中的数据库
  2. 采用dotnet watch run实现热重载
  3. 使用Swagger UI进行API测试
  4. 配置适当的launchSettings.json文件

生产环境部署

在生产环境中不使用Docker时,可以考虑:

  1. 使用IIS作为反向代理和负载均衡
  2. 配置Windows服务或Linux systemd服务
  3. 实现自动化部署脚本
  4. 设置适当的监控和日志收集系统

注意事项

  1. 确保所有依赖服务(如Redis、数据库等)都有可用的非Docker版本
  2. 测试环境差异可能导致的行为变化
  3. 性能调优方式与容器化环境有所不同
  4. 安全配置需要特别关注

通过以上方案,开发者可以灵活选择是否使用Docker,根据实际需求构建最适合的开发和生产环境。这种灵活性正是FullStackHero .NET Starter Kit作为优秀开发框架的体现之一。

登录后查看全文
热门项目推荐
相关项目推荐