草庐IT

TCP状态

全部标签

networking - Go - 从多个阅读器的 TCP 连接读取数据

我正在使用Go编程语言开发CloudServer的网络。我遇到了同时从不同的Goroutines读取相同的TCPconn的问题。这是一个简单的例子packagemainimport("fmt""net")funcmain(){addr,_:=net.ResolveTCPAddr("tcp",":8888")listener,_:=net.ListenTCP("tcp",addr)for{conn,err:=listener.AcceptTCP()iferr!=nil{fmt.Println(err)return}goHandle(conn)//outputalwayscomingfro

go - 生成 SSH 连接但检查状态?

我正在用Go编写一个程序,需要将ssh作为子进程调用,但是一旦建立连接,就可以将其用于其他事情。我想弄清楚如何检查连接是否已正确设置。问题是我等不及退出代码,因为命令在成功连接之前不会退出,但如果我不等待,那么我可能会fork进程并做其他事情但是然后子进程将遇到错误并死亡。我需要的是一种知道在某一点之后连接已成功建立的方法。例如,一种选择是让ssh建立连接,然后在建立连接后,fork拥有该连接的进程并让主进程返回成功代码。但是,我不知道ssh是否允许这种行为。 最佳答案 想通了。特别是,我正在使用“ControlMaster”连接多

调用 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

ruby - 这个示例 tcp 套接字编程事件顺序安全吗?

我计划提供两项服务。用Ruby编写的HTTPREST服务用Go编写的JSONRPC服务Ruby服务将打开一个到GoJSONRPC服务的TCP套接字连接。它将为收到的每个传入HTTP请求执行此操作。它会通过套接字向Go服务发送一些数据,然后该服务会通过套接字发回相应的数据。Go代码Go服务go看起来像这样(简化):srv:=new(service.App)//thiswouldexposeaProcessmethodrpc.Register(srv)listener,err:=net.Listen("tcp",":8080")iferr!=nil{//handleerror}for{co

go - 通过 SetDeadline() 为 TCP 监听器设置超时

我正在尝试实现非阻塞Accept(),目前为止最好的是以下代码片段(它是一个有效的Gov1.6.2程序):packagemainimport("net""log""time")funccreateClient(){tcpConn,err:=net.DialTCP("tcp4",nil,&net.TCPAddr{IP:net.IPv4(127,0,0,1),Port:12819,})iferr!=nil{log.Fatalln("Errorconnectingtotheserver!")}log.Println("Managedtodial!")tcpConn.Close()}funcm

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 - 如何从平衡器获取 gPRC 调用状态

平衡器接口(interface)Get方法有一个put函数,作为其返回之一,应该在grpc调用之后调用://Thefunctionreturnsputwhichiscalledoncetherpchascompletedorfailed.//putcancollectandreportRPCstatstoaremoteloadbalancer.https://github.com/grpc/grpc-go/blob/master/balancer.go#L74如何获取gRPC调用的状态(成功/失败)和统计信息?使用拦截器是一种替代方法,但如果可以获取状态/统计信息,我希望使用此方法。

mongodb - 在出现错误的情况下重新创建 mgo session (读取 tcp 127.0.0.1 :46954->127. 0.0.1:27017: i/o 超时)

我想知道如何使用mgo在Go中管理MongoDBsession,尤其是关于如何正确确保session已关闭以及如何对写入失败使用react。我已阅读以下内容:BestpracticetomaintainamgosessionShouldIcopysessionforeachoperationinmgo?仍然不能将其应用于我的情况。我有两个goroutine,它们将事件一个接一个地存储到MongoDB中,共享同一个*mgo.Session,两者看起来基本上如下所示:funcstoreEvents(session*mgo.Session){session_copy:=session.Cop

ubuntu - 获取连接拒绝 tcp 连接 SysLog Golang

我在golang的ubuntu16.4操作系统上使用syslog来记录如下错误。w,err=syslog.Dial("tcp","localhost:2114",syslog.LOG_ERR,"testapi")这里出现以下错误。调用tcp127.0.0.1:2114:getsockopt:连接被拒绝我已经尝试过以下事情。使用-sudoufwallow2114命令在防火墙中启用端口。禁用防火墙并尝试使用它。通过上述步骤尝试了其他端口。任何帮助将不胜感激。这是syslog.conf#/etc/rsyslog.confConfigurationfileforrsyslog.##Formor

macos - 无法连接到超过 140 个连接的 tcp 服务器?

我正在用golang构建一个TCP套接字服务器。它适用于少于~140个客户端连接。但是,如果我尝试将最大连接数设置为500,则在第140个客户端不连接到服务器后。我将文件描述符计数增加到1048576,但它仍然不起作用。$ulimit-n1048576我认为问题来自操作系统。(服务器和客户端在同一台机器上工作)所​​以操作系统信息:MacOS10.12Sierra64bit.有谁知道为什么我不能增加tcp连接数?github 最佳答案 我和你在同一个操作系统上,但我无法重现你的问题。我正在使用Go版本1.7.4。我没有在Go1.8上