问题现象:客户端linux A,服务端java B
A向B发信息, B必须在10秒内返信,若没返信 ,A timeOut时间到
则关闭socket通信, 但是当A timeOut关闭socket后, B还能够对此socket进行写(理论上A关闭socket后, B对此socket写入应该报错)原因: 客户端A关闭socket 用的close函数
close—–关闭本进程的socket id,但链接还是开着的,用这个socket id的其它进程还能 用这个链接,能读或写这个socket id
shutdown–则破坏了socket 链接,读的时候可能侦探到EOF结束符,写的时候可能会收到一个SIGPIPE信号,这个信号可能直到socket buffer被填充了才收到,shutdown还有一个关闭方式的参数,0 不能再读,1不能再写,2 读写都不能。注意
1>. 如果有多个进程共享一个套接字,close每被调用一次,计数减1,直到计数为0时,也就是所用进程都调用了close,套接字将被释放。
2>. 在多进程中如果一个进程中shutdown(sfd, SHUT_RDWR)后其它的进程将无法进行通信. 如果一个进程close(sfd)将不会影响到其它进程. 得自己理解引用计数的用法了. 有Kernel编程知识的更好理解了.
总结, 一般关闭socket的步骤:
shutdown( fd, SHUT_RDWR );
close(fd );
fd = -1;
关闭socket
最新推荐文章于 2022-06-15 11:17:56 发布