草庐IT

svn_client_log

全部标签

go - 如何修复 `kafka: client has run out of available brokers to talk to (Is your cluster reachable?)` 错误

我正在开发一个应用程序,该应用程序从sqs队列中读取一条消息,对该数据执行一些操作,然后获取结果并将其发布到kafka主题。为了在本地进行测试,我想在我的docker构建中设置一个kafka图像。我目前能够使用docker-compose在本地启动aws-cli、localstack和我的应用程序的容器。另外,我也可以毫无问题地启动kafka和zookeper。我无法让我的应用程序与kafka通信。我试过使用两个单独的撰写文件,也尝试过网络。最后,我引用了:https://rmoff.net/2018/08/02/kafka-listeners-explained/。这是我的docke

logging - 在 log.SetOutput(ioutil.Discard) 之后延迟 log.SetOutput(os.Stdout)

在go-nsq库(https://github.com/bitly/go-nsq/blob/master/writer_test.go#L38)中,我找到了以下代码:log.SetOutput(ioutil.Discard)deferlog.SetOutput(os.Stdout)为什么作者在丢弃日志后将日志记录延迟到标准输出? 最佳答案 log.SetOutput(ioutil.Discard)语句更改标准记录器输出目的地。deferlog.SetOutput(os.Stdout)语句尝试在函数结束时将输出目标重置回其初始值。但是

sockets - 如何找到 IP :Port of incoming client in TCP Connection

收到来自conn,err:=listener.Accept()的连接后,我想在conn的另一端找到客户端的地址。我已经尝试使用conn.LocalAddr()和conn.RemoteAddr()(Documentation)来执行此操作。.LocalAddr()只是给出服务器进程的地址。.RemoteAddr()为客户端提供了正确的IP,但与我所知道的客户端绑定(bind)的端口号截然不同。如果它有什么不同,我用在同一台机器上运行的两个独立进程来做这件事。一个是客户端,一个是服务器。关于如何找到客户端的正确IP:Port的任何想法?我是要使用LocalAddr还是RemoteAddr?

go - 使用 code.google.com/p/google-api-go-client/youtube/v3 的 YouTube v3 api

尝试从我的channel获取上传列表,但出现错误“ChannelContentDetails没有上传字段或方法”apiCall:=youtube.Channels.List("contentDetails").Mine(true)response,err:=apiCall.Do()iferr!=nil{log.Fatalf("ErrormakingAPIcall:%v",err.Error())}fmt.Println(response.Items[0].ContentDetails.uploads) 最佳答案 response.I

logging - Golang go-workers自定义日志记录中间件?

我正在构建一个Golang实现Sidekiq的应用程序-兼容jrallison/go-workers工作队列和围绕Sirupsen/logrus的自定义日志记录包装器用于编码的JSON日志。现在,我的所有应用程序(除了go-workers到目前为止)都在中心位置使用我的记录器包装器,以确保其输出的100%与JSON兼容。请注意,第1行和第2行是来自中央记录器的正确JSON,但是当go-workers初始化时,我们看到第3行来自错误的纯文本记录器。{"db":{"Mapper":{}},"instance_id":"1","level":"info","msg":"Db:Connecte

logging - Go:文件错误记录中的新行

我比较陌生,希望将错误注销到文本文件中。目前我使用://Loggingf,err:=os.OpenFile("pgdump_errorlog.txt",os.O_RDWR|os.O_CREATE|os.O_APPEND,0666)iferr!=nil{log.Fatalf("erroropeningfile:%v",err)}deferf.Close()log.SetOutput(f)//...(lateron)iferr!=nil{log.Fatal(err)}这工作正常,减去了错误不会产生新行并且只是附加到第一行末尾的事实。有没有办法让错误输出在附加之前创建一个新行?我试过:ife

api - 如何使用 Golang 的 github.com/google/google-api-go-client/customsearch/v1

我已经完成了人们说不需要的Oauth回调,只需要cx代码,但我还没有弄清楚如何将cx参数添加到调用中。packagemainimport("fmt""log""github.com/vinniyo/authCallback""github.com/google/google-api-go-client/customsearch/v1")funcmain(){client,err:=authCallback.BuildOAuthHTTPClient()iferr!=nil{log.Fatalf("ErrorbuildingOAuthclient:%v",err)}service,err:

logging - 如何将自定义(非 const)字符串信息添加到日志格式?

我已经开始使用Go登录,并且遇到了这篇关于登录Go的文章https://www.goinggo.net/2013/11/using-log-package-in-go.html使用以下源代码(略有改动):var(Trace*log.LoggerInfo*log.LoggerWarning*log.LoggerError*log.Logger)funcInit(traceHandleio.Writer,infoHandleio.Writer,warningHandleio.Writer,errorHandleio.Writer){Trace=log.New(traceHandle,“TR

logging - 戈朗 : How to capture panic and log this error to original log file?

我试图捕获panic并记录错误:func(s*server)SayHello(ctxcontext.Context,in*pb.HelloRequest)(*pb.HelloReply,error){deferfunc(){iferr:=recover();err!=nil{glog.Errorf("Recoveredfromerr:%v",err)}}()panic("TISHISAPANIC")return&pb.HelloReply{Message:"Hello"+in.Name},nil}但令我惊讶的是,"Recoveredfromerr:"从未出现在我的日志文件中,相反,它出

logging - 主管不写更多的日志

我正在使用supervisord来部署我的go应用,我有一个/var/log/supervisor目录,这是应用日志的目录。但是,我在某些时候发现了。没有新日志写入应用程序日志。似乎supervisord无法写入文件。可能是什么原因造成的? 最佳答案 主管无法写入日志文件可能有多种原因。也许您已经创建了不允许主管在其中写入的不同权限的日志文件。当您在应用程序配置中未指定stdout_logfile和stderr_logfile时,supervisor将在日志文件名末尾附加一个唯一ID。Supervisor只写发送到stdout和st