草庐IT

ftp_conn

全部标签

sockets - golang write net conn 不返回错误但是socket的另一端收不到数据

//onlyDatafunc(self*Packet)WriteData(wio.Writer)error{n:=len(self.Data)data:=self.Data[0:n]forn>0{wn,err:=w.Write(data)data=data[wn:n]n-=wniferr!=nil{returnerr}}returnnil}当我用net.Conn(由net.Dial("tcp")创建)调用WriteData函数时,它返回nil,但套接字的另一个端口有时无法接收到发送的数据。似乎连接中断了,但是w.Write仍然没有错误地返回。在我看来,当此套接字的另一端未收到数据包时,

go - 在 Golang 中,为什么 conn.Write tcp 响应为空?

我有一个读取文件的tcp服务器,该文件将文件内容发送到客户端。“status.txt”文件仅包含一个bool值。当我curl时,这显示true(带有前导空格)。dat,err:=ioutil.ReadFile("./status.txt")conn.Write([]byte(""+string(dat)))而此代码导致curl:(52)Emptyreplyfromserver。conn.Write([]byte(string(dat)))知道为什么会这样吗?我不想填充我的响应字符串。 最佳答案 如果您不使用HTTP协议(protoc

unit-testing - 如何在不创建实际网络连接的情况下测试依赖于 net.Conn 的代码?

如果我有适用于net.Conn的代码,我如何在不实际创建与本地主机的网络连接的情况下为其编写测试?我在网上没有看到这个问题的解决方案;人们似乎要么忽略它(不进行测试),要么编写无法并行运行的测试(即使用实际的网络连接,这会耗尽端口),要么使用io.Pipe。不过,net.Conn定义了SetReadDeadline、SetWriteDeadline;而io.Pipe没有。net.Pipe也没有,尽管表面上声称要实现该接口(interface),但它只是通过以下方式实现:func(p*pipe)SetDeadline(ttime.Time)error{return&OpError{Op:

linux - tls conn Read 中的 Golang panic - 仅在 linux 上?

我正在使用golangcrypto/tls来处理自定义的面向行的消息协议(protocol)。这种方法在Windows上运行良好:varfullBufferstringfor{//Ifwe'renotconnected,attemptreconnectifthis.conn==nil{ifthis.IsSecure(){this.conn,err=tls.Dial("tcp",this.GetHostOnly(),nil)}else{this.conn,err=net.Dial("tcp",this.GetHostOnly())}iferr==nil{//logandcontinue}

http - 在 net.Conn 之上创建一个 http 响应编写器

在下面的代码中:l,err:=net.Listen("tcp",":"+port)assert(err)c,err:=l.Accept()assert(err)cert,err:=tls.LoadX509KeyPair(TLS_CERT,TLS_PKEY)assert(err)TLSconfig:=&tls.Config{Certificates:[]tls.Certificate{cert},ClientAuth:tls.VerifyClientCertIfGiven,ServerName:DOMAIN_NAME,}tlsConn:=tls.Server(c,TLSconfig)tl

networking - 我可以使用 mime/multipart 阅读器从 Conn 读取数据吗?

我正在通过TCP套接字发送边界分隔的JSON数据。我读到golang有一个mime/multipart阅读器,我尝试使用它,但无济于事。有问题的代码是://IcreateareaderwrappedaroundaConntypewithboundarypreviouslydefinedreader:=multipart.NewReader(conn,MESSAGE_BOUNDARY)//ThenIhaveagopherwhichreadstheparts/datafromit:part,_:=reader.NextPart()varline[]bytepart.Read(line)问题

go - TCP `net.Conn.Read` 在使用 `encoding/gob` 解码器后挂起

我可以用encoding/goben/decoder包裹TCPnet.Conn的末端,并通过它成功地en/decode一个值,但是如果我遵循在卡在Read上的原始连接上使用Read进行Decode:packagemainimport("encoding/gob""net""log""sync")funcmain(){varwgsync.WaitGroupaddr:=&net.TCPAddr{IP:net.ParseIP("127.0.0.1"),Port:9000}ready:=make(chanstruct{})wg.Add(1)gofunc(){deferwg.Done()ln,e

go - conn.flush() 不会将所有记录刷新到 redis

这是代码funcmain(){...pool:=createPool(*redis_server,*redis_pass)deferpool.Close()c:=pool.Get()variint64st:=tickSec()fori=0;i如果我使用c.Close(),总集数为100000,真正的排序集数为100000。但是如果我使用c.Flush(),总数也设置为100000,真正的sortedset计数小于100000(96932);如果我在主函数的末尾使用time.Sleep(),总数也是100000。当mainfunc退出时,flushfunc没有完成?为什么?谢谢!

go - 如何在 net.Conn.Write() 中编写用户定义的结构对象

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭5年前。Improvethisquestion我有一个简单的TCP服务器监听一个端口。如何编写net.Conn.Write()中用户定义类型的对象?我的代码如下:funcmain(){ln,err:=net.Listen("tcp",":2000")iferr!=nil{log.Fatal(err)}msgchan:=make(chanstring)for{conn,err:=ln.Accept()iferr!=nil{log.Println

sockets - conn (net.Conn) 并不总是写在套接字上

我已经用服务器和客户端完成了一个应用程序,以使用套接字TCP发送信息问题是,如果函数zfs.ReceiveSnapshot(在服务器端)没有返回错误(err==nil),conn.Write([]byte("0"))不工作,客户端没有收到任何字节继续,它不能关闭连接...我给你看服务器端和客户端的代码服务器:packagemainimport("net""github.com/mistifyio/go-zfs")funcmain(){//Listenforincomingconnectionsl,_:=net.Listen("tcp",":7766")//Closethelistene