一、异步 数据库
报文发送和接收是分开的,相互独立的,互不影响。这种方式又分两种状况: windows
(1)异步双工:接收和发送在同一个程序中,由两个不一样的子进程分别负责发送和接收;二、同步 设计模式
报文发送和接收是同步进行,既报文发送后等待接收返回报文。
浏览器
同步方式通常须要考虑超时问题,即报文发出去后不能无限等待,须要设定超时时间,超过该时间发送方再也不等待读返回报文,直接通知超时返回。 缓存
在长链接中通常是没有条件可以判断读写何时结束,因此必需要加长度报文头。读函数先是读取报文头的长度,再根据这个长度去读相应长度的报文。 Socket 是应用层与TCP/IP协议族通讯的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来讲,一组简单的接口就是所有,让Socket去组织数据,以符合指定的协议。
通讯过程:
安全
主 机 A 的应用程序要能和主机 B 的应用程序通讯,必须经过 Socket 创建链接,而创建 Socket 链接必须须要底层 TCP/IP 协议来创建 TCP 链接。创建 TCP 链接须要底层 IP 协议来寻址网络中的主机。咱们知道网络层使用的 IP 协议能够帮助咱们根据 IP 地址来找到目标主机,可是一台主机上可能运行着多个应用程序,如何才能与指定的应用程序通讯就要经过 TCP 或 UPD 的地址也就是端口号来指定。这样就能够经过一个Socket 实例惟一表明一个主机上的一个应用程序的通讯链路了。 服务器
创建通讯链路
(1)当客户端要与服务端通讯,客户端首先要建立一个 Socket 实例,操做系统将为这个Socket 实例分配一个没有被使用的本地端口号,并建立一个包含本地和远程地址和端口号的套接字数据结构,这个数据结构将一直保存在系统中直到这个链接关闭。 网络
(2)在建立Socket 实例的构造函数正确返回以前,将要进行 TCP 的三次握手协议,TCP 握手协议完成后,Socket 实例对象将建立完成,不然将抛出 IOException 错误。与之对应的服务端将建立一个 ServerSocket 实例,ServerSocket 建立比较简单只要指定的端口号没有被占用,通常实例建立都会成功,同时操做系统也会为 ServerSocket 实例建立一个底层数据结构,这个数据结构中包含指定监听的端口号和包含监听地址的通配符,一般状况下都是“*”即监听全部地址。以后当调用 accept() 方法时,将进入阻塞状态,等待客户端的请求。当一个新的请求到来时,将为这个链接建立一个新的套接字数据结构,该套接字数据的信息包含的地址和端口信息正 是请求源地址和端口。这个新建立的数据结构将会关联到 ServerSocket 实例的一个未完成的链接数据结构列表中,注意这时服务端与之对应的 Socket 实例并无完成建立,而要等到与客户端的三次握手完成后,这个服务端的 Socket 实例才会返回,并将这个 Socket 实例对应的数据结构从未完成列表中移到已完成列表中。因此 ServerSocket 所关联的列表中每一个数据结构,都表明与一个客户端的创建的 TCP 链接。
备注:
Windows 下单机最大TCP链接数调整系统参数来调整单机的最大TCP链接数,Windows 下单机的TCP链接数有多个参数共同决定:如下都是经过修改注册表[HKEY_LOCAL_MACHINE \System \CurrentControlSet \Services \Tcpip \Parameters]
1.最大TCP链接数 TcpNumConnections
2.TCP关闭延迟时间 TCPTimedWaitDelay (30-240)s
3.最大动态端口数 MaxUserPort (Default = 5000, Max = 65534) TCP客户端和服务器链接时,客户端必须分配一个动态端口,默认状况下这个动态端口的分配范围为 1024-5000 ,也就是说默认状况下,客户端最多能够同时发起3977 Socket 链接
4.最大TCB 数量 MaxFreeTcbs
系统为每一个TCP 链接分配一个TCP 控制块(TCP control block or TCB),这个控制块用于缓存TCP链接的一些参数,每一个TCB须要分配 0.5 KB的pagepool 和 0.5KB 的Non-pagepool,也就说,每一个TCP链接会占用 1KB 的系统内存。
非Server版本,MaxFreeTcbs 的默认值为1000 (64M 以上物理内存)Server 版本,这个的默认值为 2000。也就是说,默认状况下,Server 版本最多同时能够创建并保持2000个TCP 链接。
5. 最大TCB Hash table 数量 MaxHashTableSize TCB 是经过Hash table 来管理的。
这个值指明分配 pagepool 内存的数量,也就是说,若是MaxFreeTcbs = 1000 , 则 pagepool 的内存数量为 500KB那么 MaxHashTableSize 应大于 500 才行。这个数量越大,则Hash table 的冗余度就越高,每次分配和查找 TCP 链接用时就越少。这个值必须是2的幂,且最大为65536.
IBM WebSphere Voice Server 在windows server 2003 下的典型配置
MaxUserPort = 65534 (Decimal)
MaxHashTableSize = 65536 (Decimal)
MaxFreeTcbs = 16000 (Decimal)
这里咱们能够看到 MaxHashTableSize 被配置为比MaxFreeTcbs 大4倍,这样能够大大增长TCP创建的速度。 数据结构