目录
问题内容
解决方法
首页 后端开发 Golang 如何使用 Golang 获取容器日志? (错误)

如何使用 Golang 获取容器日志? (错误)

Feb 08, 2024 pm 09:09 PM
容器化应用

如何使用 Golang 获取容器日志? (错误)

php小编西瓜为你带来关于如何使用Golang获取容器日志的实用指南。在容器化应用开发中,日志是非常重要的,它可以帮助我们快速定位和解决问题。本文将介绍如何使用Golang编写代码,通过Docker API获取容器的日志信息,并对常见错误进行处理。无论你是新手还是有经验的开发者,本文都将为你提供有用的技巧和示例代码,帮助你更好地利用Golang获取容器日志。让我们一起开始吧!

问题内容


我正在尝试用 golang 编写 docker 监控软件。

我的代码如下所示:

package main

import (
    "bytes"
    "context"
    "fmt"
    "time"

    "github.com/docker/docker/api/types"
    "github.com/docker/docker/client"
)

func main() {
    ctx := context.background()

    cli, err := client.newclientwithopts(client.fromenv)
    if err != nil {
        panic(err)
    }

    containers, err := cli.containerlist(ctx, types.containerlistoptions{})
    if err != nil {
        panic(err)
    }

    for _, container := range containers {
        out, err := cli.containerlogs(ctx, container.id, types.containerlogsoptions{
            showstderr: true,
            showstdout: true,
            timestamps: false,
            follow:     true,
            tail:       "40"})

        if err != nil {
            panic(err)
        }

        fmt.println("the \"" + container.image + "\" container, with the id \"" + container.id + "\" logged: ")
        fmt.println()

        buf := new(bytes.buffer)

        fmt.println(buf.readfrom(out))

        fmt.println(buf.string())
    }
    time.sleep(time.second * 3)
}
登录后复制

问题是上述代码的执行在 fmt.println(buf.readfrom(out)) 语句处停止。该代码曾经可以工作,但突然就不再工作了。它要么停止而没有错误,要么返回一个空字符串。

我尝试收集日志的客户端也是我自己编写的,如下所示:

package main

import (
    "log"
    "time"
)

func main() {
    for i := 0; i > -1; i++ {
        log.Output(1, "Hello World logged!")
        time.Sleep(time.Minute)
    }
}
登录后复制

我已经尝试过调试和检查变量,但我就是无法找到问题的根源。


解决方法


我真的不确定,因为我没有任何错误日志来证实我的假设。 但是,当 containerlogs 返回一个流(io.readcloser)时,是否可能该流本身还没有关闭?

如果有可能,您可以先进行一次试运行,通过添加超时并在每个小持续时间后记录它来测试这个理论?

一种可能的方法是

select {
case <-time.After(5 * time.Second):
    fmt.Println("Timeout exceeded while reading container logs")
case <-ctx.Done():
    fmt.Println("Context cancelled while reading container logs")
case b := <-out:
    if b != nil {
        buf.Write(b)
    }
}
登录后复制

以上是如何使用 Golang 获取容器日志? (错误)的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何在Debian 12上安装Snap 如何在Debian 12上安装Snap Mar 20, 2024 pm 08:51 PM

Snap是一个针对Linux系统设计的外部包管理器,它为您提供了安装容器化应用程序的便捷途径。通过Snap,您可以轻松地下载和安装软件包,无需担心安装额外的依赖项。该管理器会自动解决软件包所需的依赖项,确保软件包能够在您的系统上顺利运行。Snap与本地的apt包管理器相辅相成,为您提供了另一种在系统中安装和运行应用程序的选择。在本指南中,您将找到有关如何在Debian12上安装Snap的完整指南。提纲:如何在Debian12上安装Snap如何在Snap上查找包可用性如何在Snap上查找有关包的信

如何调试docker-compose?配置路径在哪里设置? 如何调试docker-compose?配置路径在哪里设置? Feb 10, 2024 pm 12:48 PM

我正在尝试调试docker-compose,即这个Go文件,以解决某些问题(这个)。为此,我设置了一个GoLang调试器gorunmain.go-f/.../project_root/docker-compose.yml-f/.../project_root/folder1/docker-compose.ymlconfig的输出符合预期,合并的配置文件.由于某种原因,我找不到代码中设置的配置文件,尽管它们必须设置在某个地方,因为输出是正确合并的配置文件。我怀疑它们一定就设置

pycharm支持什么语言 pycharm支持什么语言 Apr 18, 2024 am 10:57 AM

PyCharm 支持的编程语言包括:Python(主要支持语言)JavaScript(包括 Node.js 和 React)HTML/CSSTypeScriptJavaC/C++GoSQLDockerKotlinRust

五个精选的Go语言开源项目,带你探索技术世界 五个精选的Go语言开源项目,带你探索技术世界 Jan 30, 2024 am 09:08 AM

在当今科技快速发展的时代,编程语言也如雨后春笋般涌现出来。其中一门备受瞩目的语言就是Go语言,它以其简洁、高效、并发安全等特性受到了许多开发者的喜爱。Go语言以其强大的生态系统而著称,其中有许多优秀的开源项目。本文将介绍五个精选的Go语言开源项目,带领读者一起探索Go语言开源项目的世界。KubernetesKubernetes是一个开源的容器编排引擎,用于自

适合网络工程师的 6 个最佳 Linux 发行版 适合网络工程师的 6 个最佳 Linux 发行版 Feb 05, 2024 pm 05:20 PM

作为一个网络工程师,在考虑为工作安装Linux时,你可能会面临一个问题:在成千上万个可用的Linux发行版中,应该选择哪一个呢?不用担心,你并不是孤单的。Linux作为网络工程师的常见首选操作系统,有很多发行版适合与网络相关的任务。如果你是一名网络工程师,你可能会想要知道哪些发行版在工作中提供了最佳的功能。以下是六个被网络工程师广泛推荐的优秀Linux发行版:1、Fedora在众多Linux发行版中,Fedora是网络工程师中最受推崇的之一,原因很简单。Fedora是一个开源发行版,相当于红帽企

Go语言开发的应用领域有哪些? Go语言开发的应用领域有哪些? Apr 03, 2024 am 11:33 AM

Go语言应用于以下领域:后端开发(微服务、分布式系统)云计算(云原生应用程序、容器化应用)数据处理(数据分析、大数据引擎)网络和分布式系统(代理服务器、分布式缓存)系统工具(操作系统、实用程序)

使用 Kubernetes、Helm 和 Jenkins 轻松实现 CI/CD 管道自动化 使用 Kubernetes、Helm 和 Jenkins 轻松实现 CI/CD 管道自动化 Apr 02, 2024 pm 04:12 PM

在快节奏的软件开发环境中,快速发布版本至关重要。CI/CD(持续集成和持续部署)管道可以自动化部署过程,简化代码从开发到生产的转移。本文重点介绍如何在 Kubernetes 环境中使用 Jenkins、Helm 和 Kubernetes 设置完全自动化的 CI/CD 管道,包括:环境设置、自动化管道构建和部署到开发、登台和生产环境的步骤。通过实施这一自动化流程,开发人员可以专注于代码开发,同时将复杂的基础设施管理留给自动化,从而提高部署效率和可靠性。

Linux在云计算领域的广泛应用 Linux在云计算领域的广泛应用 Mar 20, 2024 pm 04:51 PM

Linux在云计算领域的广泛应用随着云计算技术的不断发展和普及,Linux作为一种开源操作系统在云计算领域中发挥着重要作用。由于其稳定性、安全性和灵活性,Linux系统被广泛应用于各种云计算平台和服务中,为云计算技术的发展提供了坚实的基础。本文将介绍Linux在云计算领域的广泛应用,并给出具体的代码示例。一、Linux在云计算平台中的应用虚拟化技术虚拟化技术

See all articles