草庐IT

locks_block

全部标签

c - 使用 TCP/IP : recv() blocks 的套接字编程

我正在开发一个简单的客户端/服务器项目,它将一大块数据从客户端移动到服务器。我使用TCP/IP。服务器设置监听套接字,客户端连接。首先传输一个短的16字节“header”,其中包含一些信息,包括之后要传输的数据量。然后传输大块(大约2MB),即send(socketDesc,(void*)myBuffer,bigChunkSize,0);和recv(socketDescPeer,(void*)myBuffer,bigChunkSize,0)首先,我使用winsock2在Windows下实现了客户端,它可以正常工作。我现在尝试将此实现移植到linux,在这种情况下,服务器端永远不会从re

c - Linux, C : IPv6 socket: write blocks

我有服务器和客户端应用程序,在Ubuntu1410默认内核上以IPv6运行。服务:socket监听本地TCP端口并使用select()处理新的连接和数据;客户端:socket通过TCP连接服务器IPv6地址和端口。可以成功建立连接。但是,当write()数据时,缓冲区大小为128K,它会阻塞在write()中。因为我需要写入很多数据,所以我有一个for循环来调用write()。有时,write()会成功一两次,但随后又会阻塞。我的应用支持IPv4和Ipv6。write()适用于IPv4。而且,如果我在::1上测试(服务器和客户端在同一台机器上运行),IPv6也可以工作。r=write(

sockets - 连接到本地主机时延迟低,但使用外部主机时我每秒获取 3 次数据 block

我有一个项目,每10-12毫秒传输一串小数据包,我还尝试了不同的程序,一个用C++编写,另一个用python编写,以查看我的实现是否有误,但没有任何改变。因为它在我本地连接时有效,所以我看不出编程和网络代码是如何受到指责的。我尝试更新驱动程序,但没有解决问题。我尝试用完全相同的组件和软件构建一个新桌面。它适用于该PC。老实说,对于这个烦人的问题,我找不到单一的模式或解释,更不用说解决方案了。什么会导致这种行为?它不能是缓冲区,因为它在本地工作?我尝试更改它并使客户端每秒仅发送10次数据。它不应该是数据包丢失,因为我在没有无线的本地网络上使用TCP。两台PC和一根以太网线。网页加载速度快

linux - Indy 10 以 1024 个 block 发送数据。如何增加 block 大小?

我同时开发了两个软件。一个是iOS设备的TCP客户端,用XCode开发,另一个是Linux操作系统的TCP服务器,它是在Lazarus中开发的,使用Indy10作为网络框架。我可以在服务器和客户端之间毫无问题地发送数据,然而,从服务器到客户端的数据传输速度对我来说是个问题。当从iOS客户端向Linux服务器发送数据时,我获得了每秒高达20MB的非常好的传输速度,但是当从Linux服务器向iOS客户端发送数据时,我每秒最多只能获得一百千字节(100kb)。Indy10以1024字节block的形式发送数据,我可以使用NSLog()在我的iOS应用程序中看到这一点。问题:如何更改Indy1

解决 This request has been blocked; this endpoint must be available over WSS.

1、问题使用WebSocket在本地是没有问题的,能够和前端进行正常交互,但是将项目部署到服务器上,发现和前端建立不了WebSocket的连接,打开浏览器控制台报错:Thisrequesthasbeenblocked;thisendpointmustbeavailableoverWSS.2、理解1、首先我们要明白wss协议实际是websocket+SSL,就是在websocket协议上加入SSL层,类似https(http+SSL)。2、利用nginx代理wss【通讯原理及流程】(1)、客户端发起wss连接连到nginx(2)、nginx将wss协议的数据转换成ws协议数据并转发到Worker

c - 按 block 发送数据

在C中,我必须使用tcp/ip发送一堆数据(~6.5mo)我正在使用“经典”send()。您认为将全部数据量分配给函数是个好主意,还是我应该更喜欢block方式(例如64ko的切片......) 最佳答案 给它完整的大小,然后用缓冲区的其余部分再次调用它(根据返回值)。您处理您的逻辑,让操作系统处理发送逻辑。 关于c-按block发送数据,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questio

Delphi 2007,Indy 10 - 单向传输数据 block 的最简单的 TCP/IP 设置是什么

我有一个应用程序(“服务器”)每秒更新内存中的数据block-大约100k字节。在同一网络上的其他工作站上运行着1到4个“客户端”应用程序的其他实例,这些实例需要每秒读取相同的100k图像。到目前为止,这是通过将图像写入服务器上的文件并让客户端通过网络从该文件中读取来实现的。这多年来一直没有问题,但最近(恰逢转向基于Windows8的硬件)它出现了一个问题,除了一个节点之外,所有节点都无法访问该文件。退出在此节点上运行的客户端应用程序会释放文件,然后所有人都可以再次访问它。对于这次锁定的原因,我仍然感到困惑,但我想知道它是否可能是讨论的机制here,其中文件由于网络故障而未关闭。我认为

java - 通过套接字发送 10 MB 的缓冲区 - block 还是整个 10MB?

我正在将必须从我的C++函数发送到Java的详细信息转换为字符串和将通过套接字发送的char*。我的缓冲区大小是10MB。我可以一次发送10MB还是应该拆分并作为更小的内存块发送?这两种方法有什么区别?如果我应该发送较小的内存,block大小应该是多少? 最佳答案 CanIsendthe10MBinoneshot是的。orshouldIsplitandsendaschunksofsmallermemory?没有。Whatisthedifferencebetweenthosetwoapproaches?不同之处在于,在情况1中,您让T

sql-server - ADO.NET SQLServer : How to prevent closed connection from holding S-DB lock?

我Dispose一个SqlConnection对象,但当然是itisn'treallyclosed.我需要关闭连接才能不锁定数据库对象。如何防止关闭的连接持有锁?上面这句话给不懂的解释一下:当您关闭ADO或ADO.NET连接时,实际上并没有切断与SQLServer的连接。ADO/ADO.NET基础结构保持连接,以防您再次使用它。这些连接在所谓的“连接池”中一直存在。几分钟不使用后,连接将实际上关闭。虽然,不是真的。TCP/IP有自己的方法来保持TCP连接打开几分钟(在“CLOSE_WAIT”状态)。这样做是为了防止您再次要求打开到同一IP:Port的TCP连接。如果是这样,它可以使用已

ios - 测试目标下未调用 MagicalRecord 完成 block

MagicalRecord.saveWithBlock({contextinifletitems=dictionary["items"]as?Array{foritemInfoinitems{DBItem.findOrUpdateItemWithDictionary(itemInfo,inContext:context)}}//iscalledifletsets=dictionary["item_sets"]as?Array{forsetInfoinsets{DBSet.findOrUpdateSetWithDictionary(setInfo,inContext:context)}}