在多个线程的同一TCP套接字上发出阻塞write()调用是否安全?
假设我有两个线程,T1和T2。
线程T1在TCP套接字S上进行阻塞的write()调用,以发送较大的字节B1缓冲区。字节B1的缓冲区很大,以致(a)写调用块和(b)TCP必须使用多个段来发送缓冲区。
线程T2还在同一TCP套接字S上进行了阻塞的write()调用,以发送字节B2的其他一些大缓冲区。
我的问题是这样的:
UNIX上的TCP实现是否保证B1的所有字节先于B2的所有字节发送(反之亦然)?
或者TCP可以交织B1和B2的内容(例如,TCP发送一个包含B1数据的段,然后发送一个具有B2数据的段,然后又发送一个具有B1数据的段)。
PS-我知道这样做不是一个好主意。我正在尝试确定一些我未编写的代码是否正确。
-
尝试
TL; DR: 出于编写和调试代码的目的,假定原子性是安全的,除非您的目标是生命支持系统。
如果tcp套接字上的
send(2)
(与相同write(2)
)不是原子的,那将总是不好的。从来没有充分的理由实现非原子写入。Unix和Windows的所有版本都试图保持原子写操作,但是显然很少提供保证。Linux 通常 被称为 “通常”
1.做到这一点,但即使在最近的内核中,它也存在错误。它确实尝试锁定套接字,但是在某些情况下,内存分配可能会失败,并且写入将被拆分。有关详细信息,请参阅sendmsg上的此IBM博客条目。
[链接已修复。]根据那些测试,只有AIX和Solaris完全通过了线程压力测试。甚至不知道那些系统是否有根本没有发现的故障案例。
1. TL; DR:几乎总是,即,除非存在某些错误,否则总是这样。
-
tcp套接字中不会阻塞的是?
2022-03-02 关注 0 浏览24 1答案
-
如何在非阻塞套接字上处理OpenSSL SSL_ERROR_WANT_READ / WANT_WRITE
2021-02-02 关注 0 浏览78 1答案
-
TCP套接字函数中不会产生阻塞的是
2022-03-03 关注 0 浏览26 1答案
-
停止/中断线程在等待套接字输入时被阻塞
2021-01-30 关注 0 浏览84 1答案
-
TCP套接字上的ASCII
2021-01-30 关注 0 浏览101 1答案
-
Java中的非阻塞套接字写与阻塞套接字写
2021-01-30 关注 0 浏览80 1答案
-
从另一个线程关闭套接字时,阻塞recv不会退出吗?
2021-02-01 关注 0 浏览97 1答案
-
是否可以在同一台计算机上运行套接字服务器和套接字客户端?
2021-01-30 关注 0 浏览109 1答案
-
Socket,即套接字,是一个对 TCP / IP协议进行封装 的编程调用...
2022-03-03 关注 0 浏览33 1答案
-
我可以同时从多个线程为一个套接字调用accept()吗?
2021-02-01 关注 0 浏览77 1答案