登录
首页 >  Golang >  Go问答

禁用 Docker Golang SDK 中 client.ImagePull() 方法的详细 stdout

来源:stackoverflow

时间:2024-03-12 11:33:28 337浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《禁用 Docker Golang SDK 中 client.ImagePull() 方法的详细 stdout》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

当使用 imagepull() 拉取图像时,终端中有大量标准输出显示拉取的进度,即;

{"status":"downloading","progressdetail":{"current":6433248,"total":7964517},"progress":"[========================================\u003e          ]  6.433mb/7.965mb","id":"ae5cee1a3f12"}
func PullImage(imageName string) bool {
    ctx := context.Background()
    cli, err := client.NewClientWithOpts(client.FromEnv, client.WithAPIVersionNegotiation())
    if err != nil {
        log.Error(err)
        return false
    }

    //TODO: Need to disable Stdout!!
    log.Info("\t\tPulling image " + imageName)
    out, err := cli.ImagePull(ctx, imageName, types.ImagePullOptions{})
    if err != nil {
        log.Error(err)
        return false
    }
    defer out.Close()

    io.Copy(os.Stdout, out)

    log.Info("Pulled image " + imageName + " into host")

    return true
}

我搜索了文档,但没有找到禁用 stdout 或更改详细程度的方法。

我不太理解 io.copy(os.stdout, out) 行,但据我所知,禁用它不会导致任何图像被提取。

我们如何隐藏 imagepull() 的输出?


解决方案


我不太理解 io.copy(os.stdout, out) 行,但据我所知,禁用它不会导致任何图像被提取。

io.copy 只是从 io.reader(在本例中是 io.readcloser 也是 io.reader)读取所有数据并将其写入 io.writer

我的理解是,如果您不执行此步骤,main 将在 imagepull 有机会在后台完成之前返回。

但是,如果您确实执行 io.copy,则复制会使 main 忙碌足够长的时间,以便拉取实际完成。

在上面评论中的示例中,我让 main 忙于 for / sleep 循环。

您看到所有输出的原因是...好吧,您使用 io.copy(os.stdout, out)imagepull 的输出复制到 stdout ,所以我们在 stdout 中看到 imagepull 的输出也就不足为奇了.

如果我们将所有输出复制到某个“黑洞”中,从而使输出消失,那么我们会在复制发生时保持 main 忙碌,同时抑制其所有输出。

一种方法是使用 io/ioutilioutil.discard。这是一个 io.writer,它会简单地丢弃写入其中的所有数据。

因此,只需将 io.copy(os.stdout, out) 行替换为以下内容即可:

import {
    "io/ioutil"
}

io.Copy(ioutil.Discard, out)

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>