草庐IT

信息通信

全部标签

go - go 对象组件可以以复合模式相互通信吗?

我正在尝试实现复合设计模式。我了解了如何组合对象的对象。在这个例子中,我有一个运动员和游泳功能。typeAthletestruct{namestring}typeCompositeAthletestruct{athleteAthleteTrainfunc(namestring)}但是如果我需要在创建组合对象后传递名称:comp:=CompositeAthlete{athlete:athlete,Train:Swim,}comp.Train(athlete.name)是否有可能注入(inject)一个能够读取被注入(inject)对象内部的方法;packagemainimport("fm

go - 遍历树并使用可重用组件提取信息

我在Go项目中有一棵嵌套结构树。我想遍历树并执行不同的操作,例如在树的不同级别挑选出某些结构并将它们附加到列表中,或者就地修改结构。我想使用可重用组件来执行此操作,这样我就可以专注于执行任务的实现,而不必为每个此类功能重新实现walker。到目前为止,我唯一能想到的就是这个API:typeapplyFuncfunc(*Node)funcwalker(node*Node,fapplyFunc){....for_,child:=rangenode.children(){walker(child,f)}}函数walker显然可以用来修改树,因为它传递了指向树节点的指针。我喜欢它,因为我可以单

mongodb - 如何使用golang在mongodb中插入用户信息?

我是Golang的新手。因此,我将数据从html页面插入到mongodb数据库。但是代码中有错误。代码如下:-packagemainimport("fmt""gopkg.in/mgo.v2""gopkg.in/mgo.v2/bson""html/template""log""net/http""strings")typeUSERstruct{Usernamestring`bson:"Username"json:"Username,omitempty"`Passwordstring`bson:"Password"json:"Password,omitempty"`}funcsayhell

go - SMTP 连接阅读欢迎信息

我尝试连接到smtp服务器并阅读欢迎消息。这是我的代码:packagemainimport("fmt""net""time""net/smtp""bufio")funcmain(){//attemptaconnectionconn,_:=net.DialTimeout("tcp","88.198.24.108:25",15*time.Second)buf:=bufio.NewReader(conn)bytes,_:=buf.ReadBytes('\n')fmt.Printf("%s",bytes)client,err:=smtp.NewClient(conn,"88.198.24.10

go - 使用 JSON-RPC 调用传递身份验证详细信息

我没能找到任何关于此的文档。我需要对需要传递(基本)身份验证详细信息的API进行JSON-RPC调用,但找不到使用标准net/rpc/jsonrpc包执行此操作的任何方法。下面是我的非身份验证代码的剪辑版本。varreplystringnetClient,_=net.Dial("tcp","localhost:1234")jsonClient=jsonrpc.NewClient(netClient)jsonClient.Call("someMethod",someArgs,&reply) 最佳答案 Basic-Auth是一个HTTP

go - Uber Zap 记录器不在日志语句中打印调用者信息

我正在尝试使用配置的自定义编码器将相同的消息同时发送到控制台和日志文件。在此过程中,我想显示来电者信息,但即使我按照文档中的建议使用了caller键,也不会显示相同的信息。下面是相同的示例代码packagemainimport("os""time""go.uber.org/zap""go.uber.org/zap/zapcore""gopkg.in/natefinch/lumberjack.v2")varlogLevelSeverity=map[zapcore.Level]string{zapcore.DebugLevel:"DEBUG",zapcore.InfoLevel:"INFO

go - 避免goroutines之间双向通信的死锁

我正在第一次体验Go,到目前为止我真的很喜欢goroutine和channels结构。我想知道是否有一种惯用的方法可以避免多个goroutine之间的双向通信出现死锁。考虑以下示例。共有三个goroutine:producer、worker和controller。生产者生产整数。实际上这可能是数据来了例如来自网络连接。worker从生产者那里接收数据,并对其进行一些操作它。然后,worker将修改后的数据发送给controller。在某些情况下,Controller会向worker发送命令。在里面例如,如果接收到的整数大于180,就会发生这种情况。当Controller试图向工作人员发

go - 如何构建 Kubernetes 以便将调试信息包含在可执行文件中?

在尝试调试kubelet中的panic时,我一直在尝试将delve附加到kubelet可执行文件,但没有成功:me@mycomputer:~$sudodlvattach23796couldnotattachtopid23796:couldnotopendebuginfofile和objdump--syms显示kubelet中没有调试信息:me@mycomputer:~$file_output/bin/kubelet_output/bin/kubelet:ELF64-bitLSBexecutable,x86-64,version1(SYSV),dynamicallylinked,inte

go - 如何使一个 pod 与另一个 pod 的本地主机通信

我已经在Go中实现了一个gRPC客户端服务器。我现在已经在Kubernetes中将它们设置为客户端和服务器pod,客户端在其中连接到服务器。我在我的电脑上使用vagrant(centos/7)设置了这个集群。我的问题是客户端想要访问端口8090(服务器在此端口上服务)并向服务器发送消息,但是由于它们位于不同的pod中,客户端无法访问本地主机8090,因此pod失败。我该如何解决这个问题?funcmain(){conn,err:=grpc.Dial(":8090",grpc.WithInsecure())iferr!=nil{log.Fatalf("didnotconnect:%v",e

go - 简单的服务器客户端通信不起作用

这个看似简单的例子并没有像预期的那样工作,我不好意思问这个问题,但是这里是:有一个客户端重试连接到服务器,发送消息,然后等待响应:funcclient(){varconnnet.Connvarerrerror//retryserveruntilitisupfor{conn,err=net.Dial("tcp",":8081")iferr==nil{break}log.Println(err)time.Sleep(time.Second)}//writetoserver_,err=conn.Write([]byte("request"))iferr!=nil{log.Println(er