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

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

2025-05-29 01:07:33作者:裘旻烁

在分布式微服务架构中,服务之间的依赖调用是一个常见需求。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
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
168
2.05 K
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
92
599
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
199
279
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
954
563
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Python
78
71
Git4ResearchGit4Research
Git4Research旨在构建一个开放、包容、协作的研究社区,让更多人能够参与到开放研究中,共同推动知识的进步。
HTML
25
4
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
17
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0