1、概念区别
所谓TCP短连接,是指通信双方有数据交互时,就建立一个TCP连接,数据发送完成后,则断开此TCP连接。也就是说TCP连接维持的时间比较短。一般银行网页数据交互都使用短连接。再比如说http协议中,只是连接、请求、关闭,过程时间较短,服务器若是一段时间内没有收到请求即可关闭连接。
所谓TCP长连接,是指在一个TCP连接上可以连续发送多个数据包,在TCP连接保持期间,如果没有数据包发送,需要双方发检测包以维持此连接,一般需要自己做在线维持。长连接实际是相对于通常的短连接来说的,也就是长时间保持客户端与服务端的连接状态。
2、操作过程不同
短连接的操作步骤是:连接→数据传输→关闭连接;
长连接则需要不断的维护连接的通信状态,所以过程更加复杂一点:连接→数据传输→保持连接(心跳)→数据传输→保持连接(心跳)→…→关闭连接。
3、适用范围不同
短连接通常应用于WEB网页传输的HTTP服务等。由于网站的访问量可能很大,所以此时应该适用短连接以节省服务器资源;
长连接则应用于操作频繁、数据量交大、连接数不太多的情况,例如数据库操作。由于TCP的连接建立和关闭也需要消耗较多的资源,因此在操作较为频繁的情况下,不应该使用短连接,而是要用长连接以节省系统资源。
4、特点对比
短连接的特点是:管理起来比较简单,存在的连接都是有用的连接,不需要额外的控制手段;适用于传输量较小的应用场合。
长连接的特点是:长连接建立后双方不会主动断开连接。一段时间没有动作之后,服务器段需要应用TCP的保活功能来探测客户端是否仍然在线,服务器总共发送10个这样的探测,每个间隔75秒。如果服务器没有收到任何响应,它就认为客户主机已经关闭并终止连接。在长连接的应用场景下,Client端一般不会主动关闭它们之间的连接,Client与Server之间的连接如果一直不关闭的话,会存在一个问题,随着客户端连接越来越多,Server早晚有扛不住的时候,这时候Server端需要采取一些策略,如关闭一些长时间没有读写事件发生的连接,这样可以避免一些恶意连接导致Server端服务受损;如果条件再允许就可以以客户端机器为颗粒度,限制每个客户端的最大长连接数,这样可以完全避免某个不良客户端连累后端服务。