• 请不要在回答技术问题时复制粘贴 AI 生成的内容
Xuanwo
V2EX  ›  程序员

面向应用的 Golang 统一存储层

  •  1
     
  •   Xuanwo ·
    Xuanwo · Jan 13, 2020 · 2840 views
    This topic created in 2332 days ago, the information mentioned may be changed or developed.

    Hi,我最近实现了一个库 storage,目标是成为面向应用的 Golang 统一存储层。

    用起来的感觉大概是这样:

    // Init a service.
    srv, store, err := coreutils.Open("qingstor://hmac:test_access_key:test_secret_key@https:qingstor.com:443/test_bucket_name")
    if err != nil {
        log.Fatalf("service init failed: %v", err)
    }
    
    // Use Storager API to maintain data.
    ch := make(chan *types.Object, 1)
    defer close(ch)
    
    err := store.List("prefix", pairs.WithFileFunc(func(*types.Object){
        ch <- o
    }))
    if err != nil {
        log.Printf("storager listdir failed: %v", err)
    }
    

    希望大家能来看看并提一些改进的意见~

    6 replies    2020-01-14 13:00:33 +08:00
    awm47
        1
    awm47  
       Jan 13, 2020
    莫名的感觉和 https://github.com/rclone/rclone 这个仓库实现的东西有点像
    Xuanwo
        2
    Xuanwo  
    OP
       Jan 13, 2020 via Android
    @jaynos 这个库的设计目标就是让大家可以轻松的实现 rclone 这样对接多个存储后端的应用,不需要再每个都实现一遍
    hankai17
        3
    hankai17  
       Jan 13, 2020 via Android
    能压测么?
    Xuanwo
        4
    Xuanwo  
    OP
       Jan 14, 2020
    @hankai17 什么层面的压测?
    zunceng
        5
    zunceng  
       Jan 14, 2020
    现在各种对象存储 接口都是兼容 s3 的
    写的多 每个都要测试 也挺累的
    Xuanwo
        6
    Xuanwo  
    OP
       Jan 14, 2020
    @zunceng 之后会采用 BDD 测试的形式来做集成测试,只有少部分逻辑才会专门写单测了
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5028 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 09:42 · PVG 17:42 · LAX 02:42 · JFK 05:42
    ♥ Do have faith in what you're doing.