NVIDIA开源的Go依赖注入神器:gontainer,真香!

简介: gontainer 是 NVIDIA 开源的零依赖 Go DI 容器,基于泛型+反射实现函数签名自动注入,无需代码生成。支持懒加载、生命周期管理、可选/批量依赖,轻量易用,适合中小型项目,让 Go 依赖注入回归简洁本质。(239字)

推荐阅读

Gin 1.12新版本发布:这个新特性让开发者少写一半代码!
最新我用AI开发了自己的第一个博客网站:https://golangai.site ,可前往阅读公众号的文章。

写Go还在手动NewXXX(db, logger, config)?NVIDIA悄悄开源了这个零依赖的DI容器,看完直呼:早该这样了!


🔍 gontainer 是什么?

一句话:用函数签名自动注入依赖的轻量级容器,零外部依赖、零代码生成,纯靠 Go 泛型 + 反射实现。

image.png

// 以前:手动组装,写到怀疑人生
svc := NewUserService(
    NewDatabase(NewConfig()),
    NewLogger(),
    NewCache(),
)

// 现在:声明依赖,自动注入✨
gontainer.NewFactory(func(db *Database, log *Logger) *UserService {
   
    return &UserService{
   db: db, log: log}
})

⚡ 核心亮点:简单到离谱

特性 说明 爽点
🎯 自动注入 按函数参数类型匹配依赖 不用写wire.go,不用跑go generate
🚀 懒加载 服务真正用到时才创建 启动快,内存省
🔄 生命周期 自动反向清理资源 defer级体验,容器级管理
🧩 零依赖 纯标准库+泛型 go.mod清爽到哭

💡 进阶玩法:不止于"自动注入"

1️⃣ 可选依赖?安排!

gontainer.NewFactory(func(metrics gontainer.Optional[*Metrics]) *API {
   
    if m := metrics.Get(); m != nil {
   
        api.WithMetrics(m) // 有就用,没有也不崩
    }
    return api
})

适合插件化架构:核心功能不依赖可选模块,解耦满分💯

2️⃣ 批量注入接口实现?也支持!

type Middleware interface {
    Process(http.Handler) http.Handler }

gontainer.NewFactory(func(mws gontainer.Multiple[Middleware]) *Router {
   
    for _, mw := range mws {
     // 所有实现Middleware的自动收集
        router.Use(mw)
    }
    return router
})

中间件、钩子、处理器…批量注册,优雅到像写配置🎨


🤔 个人锐评:它适合你吗?

推荐场景

  • 中小型微服务/CLI工具,追求启动速度
  • 团队不想维护复杂DI框架(比如google/wire
  • 希望依赖关系"看得见摸得着",调试友好

谨慎使用

  • 超大型单体应用(可能需要更细粒度的生命周期控制)
  • 需要循环依赖的场景(设计上就该避免🙅)

💬 深度看法:gontainer 的哲学是"约定优于配置"——你用函数签名声明依赖,它用反射帮你连线。这种"显式声明+隐式组装"的平衡,恰恰是Go语言"简单但不简陋"精神的体现。


🎯 30秒上手示例

package main

import "github.com/NVIDIA/gontainer/v2"

type DB struct{
    url string }
type Service struct{
    db *DB }

func main() {
   
    gontainer.Run(
        gontainer.NewFactory(func() *DB {
    
            return &DB{
   url: "postgres://local"} 
        }),
        gontainer.NewFactory(func(db *DB) *Service {
    
            return &Service{
   db: db}  // db自动注入!
        }),
        gontainer.NewEntrypoint(func(svc *Service) {
   
            // 直接用,爽!
        }),
    )
}

相关文章
|
29天前
|
人工智能 开发者 C++
Claude Code 搞了个UltraPlan:Agent开始上云写代码了!
UltraPlan是Anthropic推出的AI编程新范式:将代码规划“动脑”环节移至云端,终端专注“动手”,实现不卡顿、可协作、灵活执行。支持精准评论、异步运行与多端同步,兼顾效率与隐私选择权。(239字)
269 5
|
29天前
|
人工智能 前端开发 IDE
Cursor 3.1 更新:智能体窗口终于「摊平」了,说话即编程!
Cursor 3.1重磅更新!平铺布局支持多智能体分屏协作,语音输入2.0实现高准度实时转写,新增分支预选防误操作,Diff跳转+文件筛选提升代码审查效率。真实场景驱动,丝滑体验拉满——懂开发者,更懂痛点。(239字)
312 0
|
29天前
|
人工智能 小程序 机器人
超详细!OpenClaw一键部署实操教程,快速上手不踩坑
OpenClaw是开源AI智能体,可处理文件、操控浏览器、接入钉钉等IM工具。本文详解阿里云三大一键部署方案(轻量服务器/计算巢/无影云电脑),2步完成部署,零代码配置,助你快速启用“数字员工”!
517 5
|
29天前
|
安全 JavaScript 前端开发
Burp Suite Professional 2026.4 发布 - 领先的 Web 渗透测试软件
Burp Suite Professional 2026.4 发布 - 领先的 Web 渗透测试软件
184 1
Burp Suite Professional 2026.4 发布 - 领先的 Web 渗透测试软件
|
29天前
|
人工智能 弹性计算 机器人
超详细!Hermes Agent一键部署实操教程,快速上手不踩坑
Hermes Agent是Nous Research开源的自主AI智能体,支持自进化、持久记忆与多平台接入。阿里云提供轻量服务器、计算巢、无影云电脑三大一键部署方案,最快两步完成,新手30分钟即可上手实操!
822 1
|
29天前
|
人工智能 Linux Docker
Docker 部署 Open WebUI + Ollama 完整教程(Windows / Linux 通用)—— 打造自己的本地OpenAI
无需复杂配置!Docker一键部署Open WebUI+Ollama,Windows/Linux通用,新手也能轻松上手。无需依赖云端,打造专属本地OpenAI,实现可视化聊天交互,兼顾数据隐私,还附带常见问题排查,全程步骤清晰,快速拥有本地大模型平台!
1056 0
Docker 部署 Open WebUI + Ollama 完整教程(Windows / Linux 通用)—— 打造自己的本地OpenAI
|
4天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全+三种模式+记忆体系+实战工作流完整手册
Claude Code 是当前最流行的终端级 AI 编程助手,能够直接在命令行中完成代码生成、项目理解、文件修改、命令执行、错误修复等全流程开发工作。它不依赖图形界面、不占用额外资源,却能深度理解项目结构,自动生成规范代码,大幅提升研发效率。
809 2
|
29天前
|
测试技术 Linux iOS开发
Burp Suite 2026.4 (macOS, Linux, Windows) - Web 应用安全测试和扫描
Burp Suite 2026.4 (macOS, Linux, Windows) - Web 应用安全测试和扫描
265 2
Burp Suite 2026.4 (macOS, Linux, Windows) - Web 应用安全测试和扫描
|
29天前
|
缓存 小程序 算法
外卖配送小程序开发核心难点:调度系统与订单分发机制解析
外卖配送小程序开发的核心不在前端界面,而在后端两大能力:智能调度系统(决定配送效率)与科学订单分发机制(保障稳定性和骑手体验)。多数项目“能用但跑不动”,症结恰在此——缺乏多约束实时优化、动态评分派单、多单路径规划及高并发架构设计。
|
29天前
|
Shell 程序员 开发工具
Git-2.15.0-64-bit安装步骤详解(附环境变量配置与基础使用)
Git-2.15.0-64-bit是Windows 64位系统专用的Git版本控制工具安装包,支持Win7/10/11。含Git Bash、GUI及资源管理器集成,配置灵活(含PATH、编辑器、凭据管理等),安装后可直接命令行调用,程序员协作开发必备。