套接字选项总结:
SO_REUSEADDR:
1)SO_REUSEADDR允许启动一个监听服务器并捆绑其众所周知的端口,即使以前建立的将
该端口用作他们的本地端口的连接仍存在。这个条件通常是这样碰到的:
a)启动一个监听服务器,
b)连接请求到达,派生一个子进程来处理这个客户
c)监听服务器终止,但子进程继续为现有连接上的客户提供服务
d)重启监听服务器
默认情况下,当监听服务器在步骤d通过调用socket,bind和listen重新启动时,由于它试图绑定一个现有连接
上的端口(即正由早先派生的那个子进程处理着的连接)上的端口,从而bind调用会失败,但是如果该服务器在
socket和bind调用之间设置了SO_REUSEADDR套接字选项,那么bind会成功(注意设置这个选项的顺序,在bind之前).
所有的tcp服务器都应该指定本套接字选项,以允许服务器在这种情形下被重新启动。
2)SO_REUSEADDR允许在同一端口上启动同一服务器的多个实例,只要每个实例捆绑一个不同的本地ip地址即可。
对于tcp我们绝不可能启动捆绑相同的ip地址和相同端口号的多个服务器,这是完全重复的捆绑。
3)SO_REUSEADDR允许单个进程捆绑同一端口到多个套接字上,只要每次捆绑指定不同的ip地址即可
4)SO_REUSEADDR允许完全重复的捆绑,但是本特性一般仅支持udp套接字.