首页
/ BentoML 1.4版本新特性:支持从URL依赖外部服务

BentoML 1.4版本新特性:支持从URL依赖外部服务

2025-05-29 06:12:26作者:裘旻烁

在分布式微服务架构中,服务之间的依赖调用是一个常见需求。BentoML作为一款流行的机器学习模型服务框架,在1.4版本中引入了一项重要功能:支持通过URL直接依赖外部部署的服务实例。

功能概述

传统上,在BentoML中,服务之间的依赖通常需要在同一个BentoML环境中定义和部署。1.4版本新增的from_url依赖注入方式,允许开发者直接引用已经部署在远程的服务实例,无需将这些服务打包在同一个Bento项目中。

这项功能特别适合以下场景:

  • 跨团队协作时,不同团队负责的服务独立部署
  • 需要集成第三方提供的模型服务
  • 在混合云环境中,服务部署在不同基础设施上

技术实现

通过bentoml.depends.from_url装饰器,开发者可以声明式地指定外部服务的URL和输入输出类型。框架会自动处理服务发现、协议转换和类型检查等底层细节。

一个典型的使用示例如下:

@bentoml.service(
    traffic={"timeout": 600},
    workers=8,
    resources={"cpu": "1"}
)
class ControlNet:
    controlnet_service = bentoml.depends.from_url(
       url="http://already.deployed-bento.com:3000",
       input=Annotated[torch.Tensor, Shape((1, 4)), DType("float32")],
       output=Annotated[torch.Tensor, Shape((1, 4)), DType("float32")],
    )

    @bentoml.api
    async def generate(self, image: PIL_Image, params: Params) -> PIL_Image:
        # 使用controlnet_service处理逻辑

技术优势

  1. 松耦合架构:服务之间不再需要强依赖,可以独立演进和部署
  2. 类型安全:通过类型注解确保服务间调用的接口兼容性
  3. 简化部署:避免将所有服务打包成单一Bento包带来的复杂度
  4. 协议透明:底层自动处理HTTP/gRPC等通信协议细节

最佳实践

在使用此功能时,建议考虑以下几点:

  1. 服务发现:对于生产环境,建议结合服务发现机制而非硬编码URL
  2. 超时设置:根据网络延迟情况合理设置调用超时
  3. 熔断机制:考虑实现熔断逻辑处理依赖服务不可用情况
  4. 版本管理:即使通过URL调用,也应考虑服务接口版本兼容性

总结

BentoML 1.4的这一新特性大大提升了框架在分布式场景下的适用性,使得构建基于微服务架构的机器学习应用更加灵活和高效。开发者现在可以更自由地设计服务拓扑结构,同时享受BentoML提供的类型安全和部署便利性。

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

项目优选

收起
kernelkernel
deepin linux kernel
C
24
7
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
376
3.26 K
flutter_flutterflutter_flutter
暂无简介
Dart
619
140
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
62
19
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.03 K
479
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
647
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.09 K
619
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
790
76