草庐IT

ELK堆栈

全部标签

syntax - 如何将自定义结构放入堆栈然后能够访问所有字段?

我有一个包含字段Field_1和Field_2的结构Foo。packagefootypeCustomstruct{start_rowintstart_columnintmove_rowintmove_columnint}typeFoostruct{Field_1[100]CustomField_2stack.Stack}如何初始化Foo?像这样,new_element:=&foo.Foo{[100]foo.Custom{},stack.Stack{}}但是我需要指定stack作为foo.Customstruct的容器,因为我需要像这样访问后面的start_row,start_colum

go - 通过堆栈管理和提供 html/模板数据绑定(bind)

有没有人在使用Go的html/template时实现了管理View绑定(bind)的解决方案?具体来说,我希望找到能让我做类似事情的东西:在安装过程中设置全局Site.Title提供请求范围的变量,如CurrentURL然后,在Render步骤中,只需提供特定于http.Handler的变量,然后将其组合并提供给模板。现有应用程序的示例如下所示(我使用unrolled/render进行布局继承,但这是可替换的):packagemainimport("log""net""net/http""os""strings""github.com/go-chi/chi""github.com/go

go - Cadvisor 支持 ELK 堆栈

ELKstack被大量使用,但cAdvisor只支持influxdb。所以我想基于Lumberjack协议(protocol)实现一个日志存储转发驱动器。我认为cAdvisor可以将指标数据转发到LogStash。所以我打算着手解决这个问题。但我真的不知道如何开始编码。https://github.com/google/cadvisor/issues/634 最佳答案 我已经在ElasticSearch中实现了商店指标数据。请参阅https://github.com/google/cadvisor/pull/875

Mongodb 对例程的查询会产生巨大的堆栈跟踪

我正在对go程序中的api进行大量网络调用,结果存储在数据库中(使用mgo)。api调用是在单独的go例程上完成的。在其他例程中,我会在更新数据库之前从数据库中提取信息并对其进行处理。当数据被放回时,会设置一个标志,以便知道该数据已经过后处理,因此当程序向数据库请求另一个条目以进行后处理时,数据库会返回一个标志complete设置为false。当标志设置为true时,go例程将关闭:wg.done()。一切都很好,我有很多打印输出告诉我程序是如何进行的,但是在运行结束时我得到一个包含很多相同内容的巨大堆栈跟踪:goroutine56731[sleep]:time.Sleep(0x12a

amazon-web-services - aws-sdk-go describeStacks() 试图获取 stackids 列表或从堆栈名称获取 stackid

首先,我为我的英语道歉,我建议我是Go的新手。我正在尝试获取我的opsworks堆栈中所有stackId的列表,或像我对ruby​​sdk所做的那样提供堆栈名称并获取堆栈ID,以便我可以与其他服务调用一起使用,但现在我正在尝试让它们全部熟悉sdk。funcmain(){svc:=opsworks.New(session.New(&aws.Config{Region:aws.String("us-east-1"),Credentials:credentials.NewSharedCredentials("","development"),}))resp,err:=svc.Describe

logging - 将结果堆栈跟踪默认写入文件

我在我的程序中使用从模式定义的记录器,如下所示var(logFile*os.FileInfo*log.Logger)funcinit(){varerrerrorlogFile,err=os.OpenFile("/my/file/with.log",os.O_CREATE|os.O_APPEND|os.O_WRONLY,0666)iferr!=nil{fmt.Printf("Cannotopenlogfileerror:%s.Programwasterminated.",err)os.Exit(1)}Info=log.New(logFile,"INFO:",log.Ldate|log.L

go - 获取 "parent"goroutine 的堆栈以及 "child"的堆栈

是否有一种方法,可能打开了一些调试标志,以获取所有goroutine的堆栈跟踪转储以及“父”goroutine的堆栈跟踪(此处使用“parent”表示goroutine执行了对gofoo()的调用,启动了相关的goroutine)。这个问题的背景是我有一个连接泄漏并注意到awaitDone(在sql包中)有很多goroutines被阻塞,并且这些goroutines是在创建连接的地方产生的。 最佳答案 runtime.Stack()将为您提供运行时知道的所有堆栈信息。阅读输出可以看到,对于Goroutines,它们被设计为不包含其祖

multithreading - 具有分层输出的堆栈跟踪

我正在调试一个包含很多似乎死锁的goroutines的go程序。我想在它卡住时有一个堆栈跟踪。但是输出很长,不适合我的终端缓冲区。所以我想把它输出到一个文件中。但是,如果我将stderr输出到文件,我无法(轻松地)检测到它何时卡住。我希望tee适合这个:去测试./foo-v|&teelog.txt但是,当我按下Ctrl+Alt+\时,终端或文件中均未显示任何堆栈跟踪输出。不知何故,它似​​乎无法通过tee的旅程。有更好的方法吗? 最佳答案 根据MarkPlotnick的评论,在tee工作之前捕获SIGQUIT信号(至少对我而言):去

go - 如何在不修改堆栈的情况下将表的内容转储到堆栈中?

首先,我非常喜欢Lua。从字面上看是从昨天晚上开始的。顺便说一句,我正在使用golua据我了解,它非常接近地反射(reflect)了通常的CAPI。因此,C中的任何建议也可能适用于我的情况。总之,正题。我(自然地)很早就开始了将Lua集成到Go应用程序中的实验,因此正在测试各种方法和做事的方式。我要做的第一件事就是调用一个带有表(基于JSON对象)的Lua函数,对表执行一些操作,然后返回它。该表可能包含嵌套表。脚本部分在这里不是问题,我想我已经涵盖了这一点。但是,我想查看堆栈内部以验证我传递给函数的内容是否正确。同样也可以查看从Lua返回的值。但是如何呢?这一位被占用fromthere

go - 在 Ragel 中使用带有扫描仪 block 的堆栈的正确方法是什么?

我在Go中使用Ragel6.10。我确定这可能是我的代码有问题,但是当我尝试将堆栈与扫描仪block一起使用时,我遇到了一些奇怪的错误。我正在尝试设置括号匹配,我的代码大致如下所示;ObjectValues:=|*#otherstuff'}'=>{fret;};*|main:=('{'@{fcallObjectValues;})*;查看指南中的第46页,看起来这应该是可能的。当我运行Ragelragel-G2-Zmain.rl时。当我尝试编译时出现以下错误(它只发生在-G2FSM生成时);graphql_collections.rl:47[/Users/nathanfisher/wor