草庐IT

stream_socket_client

全部标签

调用 Go RPC TCP 服务时 Ruby Socket 客户端挂起

我有一个用Go编写的工作RPCTCP服务,但是当使用Ruby连接到服务时它挂起,因为似乎没有数据通过打开的套接字连接发回。远程RPC函数:packageremoteimport"fmt"//ComposeisourRPCfunctionsreturntypetypeComposestring//DetailsisourexposedRPCfunctionfunc(c*Compose)Details(argstring,reply*string)error{fmt.Printf("Argreceived:%+v\n",arg)*c="somevalue"*reply="Blah!"ret

sockets - UDP 代理,如何维护/重用/清除连接的客户端池?

我正在创建一个UDP-proxy在go,但在使用iperf进行一些负载测试时,我开始收到此错误:socket:toomanyopenfiles经过搜索和测试,我发现如果我使用map创建一个池打开连接是关键*net.UDPAddr.String()value是UDP-proxy的一个实例包含*net.UDPConn,如果客户端地址相同,我可以重用现有连接:varclientsmap[string]*UDPProxy.UDPProxy=make(map[string]*UDPProxy.UDPProxy)这blockcode看起来像://waitforconnectionsfor{n,cl

go - YouTube API : Go client: can't change playlist item position

这是我编写的用于更改播放列表项位置的函数:varservice*youtube.ServicefuncsetPlaylistItemPosition(item*youtube.PlaylistItem,iint64)error{ifitem.Snippet==nil{returnerrors.New("playlistitemsnippetisnull")}item.Snippet.Position=iresponse,err:=service.PlaylistItems.Update("snippet",item).Do()iferr!=nil{returnerr}ifrespons

sockets - 检索确切的连接 - tcp 套接字 - channel - goroutine

我正在学习Golang几天,所以我不清楚如何在函数内检索正确的连接“conn”函数处理消息对于相关消息“msg”谢谢!packagemainimport("fmt""log""net""os""encoding/json""time""bufio")typePacketstruct{PayloadPayload`json:"payload"`}typePayloadstruct{Datastring`json:"data"`}funcmain(){iflen(os.Args)!=2{fmt.Fprintf(os.Stderr,"Usage:%shostname\n",os.Args[0

go - 将 *extensions.Deployment 转换为 *v1beta1.Deployment (Kubernetes client-go)

对于Kubernetesclient-go,如何使用Convert()将*extensions.Deployment转换为*v1beta1.Deployment?当我运行下面的程序时,出现此错误:2017/01/1222:40:42转换失败:将(extensions.Deployment).CreationTimestamp.Time.sec转换为(v1beta1.Deployment).CreationTimestamp.Time.sec:无法设置目标。(试图用未导出的字段深度复制某些东西?)packagemainimport("log"_"k8s.io/client-go/1.4/

http - 如何在 Go 中绑定(bind)一个 http.Client 到一个 IP 地址

我有一台带有多个NIC的客户端机器,如何将Go中的http.Client绑定(bind)到某个NIC或某个SRCIP地址?假设您有一些非常基本的http客户端代码,如下所示:packagemainimport("net/http")funcmain(){webclient:=&http.Client{}req,_:=http.NewRequest("GET","http://www.google.com",nil)httpResponse,_:=webclient.Do(req)deferhttpResponse.Body.Close()}有没有办法绑定(bind)到某个网卡或IP?

c - O_NONBLOCK SOCK_STREAM 限制为 8192

我正在从C程序写入SOCK_STREAM正在从go程序监听的Unix域套接字,使用net.Listen("unix",sockname).当我将套接字设置为O_NONBLOCK使用fcntl(),我看到C程序在第一次写入时只写入了8192字节。失败后,我监控并回写剩余数据,但我服务器上读取的数据在这种情况下是无效的。当我不使用O_NONBLOCK时,然后整个8762字节被写在一个单一的写入中,一切都按预期工作。C客户端套接字连接if((fd=socket(AF_UNIX,SOCK_STREAM,0))==-1){return;}intflags=fcntl(fd,F_GETFL,0);

Golang unix 套接字 : registering same type for RPC on different sockets?

我在Go中工作,对使用unix套接字有点陌生。尝试搜索类似的问题,但找不到任何内容,如果之前已经回答过,我们深表歉意。我想用unixsockets模拟一个机器集群进行测试。我正在测试我的Raft实现,所以我想在不同的unix套接字上注册相同类型的多个对象(一个庞大的结构)。但是看我写的一个简单的例子,效果似乎不是我想要的:为同一个导出方法拨不同的套接字似乎在单个端口上崩溃:packagemainimport("net""fmt""net/rpc""log""sync")typeServerstruct{namestring}typeSpeakArgsstruct{}typeSpeakR

go - Golang扫描函数中 "ERROR: IOError: closed stream"如何处理?

我在Golang代码中使用knifebootstrap命令来引导节点。有时食谱中有等待,等待超过10分钟。在这种情况下,我收到错误“错误:IOStream关​​闭”。有什么办法可以增加时间限制吗?我也在不断地从cmd的输出和错误流中读取日志。funcexecuteCMDWorkstation(cmd*exec.Cmd,projectId,cr_idstring)bool{stdout,err3:=cmd.StdoutPipe()iferr3!=nil{utils.Info.Println(err3)returnfalse}deferstdout.Close()stderr,err4:=

go - 操作 Kubernetes 的 client-go PodList

我正在研究Kubernetesclient-go,无法理解操作Pod结构的正确方法...我得到一个PodListpods像这样://createstheclientsetclientset,err:=kubernetes.NewForConfig(config)iferr!=nil{glog.Fatal(err)}//GetPodspods,err:=clientset.CoreV1().Pods("").List(meta_v1.ListOptions{})iferr!=nil{fmt.Println(err)return}然后我可以获得每个Pod的一些值使用像这样的循环for_,p