草庐IT

Java TCP 套接字 : data transfer is slow

全部标签

sockets - 如何读取在 Golang 中接收到的 UDP 数据报的输入接口(interface)和远程套接字地址?

PacketConn.ReadFrom()可以为输入接口(interface)提供包含ifIndex的ControlMessage。UDPConn.ReadFromUDP()返回带有数据报的源套接字地址(srcIP+srcPort)的net.UDPAddr。但是,如何同时获取两个信息:输入接口(interface)ifIndexAND远程套接字地址(srcIP+srcPort)?编辑:我已经填写了一个问题:https://github.com/golang/go/issues/14362 最佳答案 当底层套接字是UDP时,.Read

go - 一个套接字到达多个地址

我必须向网络中的每台主机发送一个UDP数据包,比如N台主机。我当前的C实现非常简单:打开一个UDP套接字在每个主机的同一个套接字上使用sendto对于Go,我有net.Conn(Connection),而不是套接字。如何只使用一个fd将UDP数据包发送到不同的主机?现在我必须关闭并打开net.ConnN次。预先感谢您的帮助:) 最佳答案 使用net.ListenUDP创建一个具有所需本地端口的UDP套接字(或0以获取分配的可用端口)。这会给你一个net.UDPConn其中有WriteTo和ReadFrom方法(相当于sendto和r

list - Golang - 链接到 id 的套接字片段以进行通知

我想制作一个结构片段,其中包含一个id和一个套接字,用于从我的服务器发送通知。每个套接字都必须初始化,我了解套接字的工作原理,因为我已经使用过它(在C语言中,使用select()为学校项目集群)。但是我不明白如何将每个新连接分离到我的slice的一个元素中(当我阅读systembash中的示例时)..很难说我不明白什么,如果你给我留言不明白!谢谢! 最佳答案 创建一个包含conn和id的结构:typeConnDetailsstruct{connectionnet.Connidint}使用它来初始化你的slice:varconnect

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

sockets - UDP 套接字未从 Go 中的服务器读取

我正在开发一个快速的dns客户端,只是为了搞乱但是我在读取服务器响应时遇到了麻烦,因为它永远不会到达,我知道它确实做到了,因为我打开了WireShark,它读取了数据包。这是代码示例(8.8.8.8是GoogleDNS,十六进制消息是有效的DNS查询):packagemainimport("fmt""net""encoding/hex""bufio")funcCheckError(errerror){iferr!=nil{fmt.Println("Error:",err)}}funcmain(){Conn,err:=net.Dial("udp","8.8.8.8:53")CheckEr

Mongodb unix 套接字与官方 mongo-go-driver 的连接?

找不到任何关于unix域套接字连接支持官方mongo-go-driver的信息。它是否得到官方实现和支持?“mongodb:///tmp/mongodb-27017.sock”uri不起作用。 最佳答案 Isitimplementedandsupportedofficially?使用官方MongoDBGodriver您可以直接连接到URI套接字。您只需要转义斜线即可。例如使用v1.1+:mongoURI:="mongodb://%2Ftmp%2Fmongodb-27017.sock"client,err:=mongo.NewClie

sockets - 如何从套接字读取数据,直到客户端停止发送?

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭7年前。Improvethisquestion我有一些问题。我有客户端和服务器。客户端通过TCP与服务器连接。然后,客户端发送一些数据(由block分隔),我不知道数据的长度是多少(TLS握手)。但是我知道客户端发送一些固定长度的数据,然后停止,直到没有收到一些响应,然后他再次发送固定长度的数据。我需要读取所有block,直到客户端停止发送(因为有太多block)。怎么做?我只有一个想法,超时。循环读取数据并设置迭代之间的超时。如果超时结束,

go - Golang 中带有 TCP/IP 套接字的 channel 无法正常工作

我刚开始为我用C语言用TCP/IP套接字制作的服务器编写Golang客户端,然后我发现我的channel无法正常工作。有什么想法吗?funcreader(rio.Reader,channelchan使用netcat测试我的服务器会产生以下输出:http://pasted.co/a37b2954但我只有:http://pasted.co/f13d56b4我是Golang的新手,所以也许我错了(我可能是错的) 最佳答案 channel使用看起来没问题,但是从channel中检索值会覆盖先前在buf:=处读取的值因为你在等待换行。您也可以

java - 通过套接字将数据从 C++ 程序移植到 Java 程序的输入是否比通过服务器上的原始 json 或 xml 文件更快?

就速度/性能而言,处理事情的最佳方法是什么?“ApacheThrift”之类的东西从哪里来,有什么好处?请添加一些我可以用来了解任何建议的好资源!谢谢大家 最佳答案 假设您的意思是两个进程都已在运行,那么它将通过套接字运行。从一个进程将文件写入磁盘然后从另一个进程读取它会导致磁盘写入和读取的性能下降(当然还有您使用任何方法来阻止读取器访问文件直到完成正在写入;磁盘上的锁定或原子重命名)。即使忽略这一点,您的本地主机接口(interface)也将具有比磁盘Controller更快的传输速率,但其中包含15kRPM驱动器的10Gb光纤c

java - 从java中的套接字读取多个xml文档

我正在编写一个需要通过套接字读取多个连续的小型XML文档的客户端。我可以假设编码始终是UTF-8,并且可以选择在文档之间分隔空白。文档最终应该进入DOM对象。完成此任务的最佳方法是什么?问题的实质是解析器期望流中有单个文档,并考虑其余内容垃圾。我认为我可以通过跟踪元素深度并使用现有输入流创建新阅读器来人为地结束文档。例如。像这样的东西://BrokenpublicvoidparseInputStream(InputStreaminputStream)throwsException{XMLInputFactoryfactory=XMLInputFactory.newInstance();