20 HTTP 长连接与短连接
每日一句
纸上得来终觉浅,绝知此事要躬行。
每日一句
Never give up until the fight is over.
永远不要放弃,要一直战斗到最后一秒。
概念
长连接
指在一个TCP连接上可以连续发送多个数据包。
在TCP连接保持期间,如果没有数据包发送,需要双方发检测包以维持此连接,一般需要自己做在线维持。
短连接
指通信双方有数据交互时,就建立一个TCP连接,数据发送完成后,则断开此TCP连接。
HTTP的长连接和短连接本质上是TCP长连接和短连接。
HTTP属于应用层协议,在传输层使用TCP协议,在网络层使用IP协议。
IP协议主要解决网络路由和寻址问题,TCP协议主要解决如何在IP层之上可靠的传递数据包。
从HTTP/1.1起,默认使用长连接,用以保持连接特性。使用长连接的HTTP协议,会在响应头有加入这行代码:Connection:keep-alive
连接过程
短连接操作步骤是:
连接→数据传输→关闭连接;
长连接通常就是:
连接→数据传输→保持连接(心跳)→数据传输→保持连接(心跳)→……→关闭连接
使用场景
长连接:
多用于操作频繁,点对点的通讯,而且连接数不能太多情况.
如数据库连接
短连接
web网站的http服务。长连接更加耗费服务器资源。bulabula…
美文佳句
把握分寸,是一种难得的智慧。那些能看到别人优点的人,往往懂得把别人放在心上,时刻照顾别人的感受。他们会在一言一语中放低自己的姿态,让别人感受到关心和尊重。
人与人之间,不过一场以心换心。学会欣赏别人,别人才会欣赏你。对他人适时地赞美,不需要多么高超的说话技巧,比技巧更重要的是真诚。真心实意、以诚相待,永远是人际交往中最基本的准则。
面试题
HashMap、ConcurrentHashMap 和Hashtable有什么区别?
HashMap | ConcurrentHashMap | Hashtable | |
线程是否安全,以及实现线程安全的方式 | HashMap不安全 | 线程安全,ConcurrentHashMap JDK1.7底层采用分段锁,对整个桶数进行了分割分段(segment), 每一把锁只锁容器其中一部分数据,提高并发访问率。 JDK 1.8 底层采用 Node数组 + 链表 + 红黑树的结构实现, 并发控制使用了 synchronized 和 CAS 操作。 |
线程安全,底层采用synchronized 来保证线程安全, 直接是方法级别的加锁, ConcurrentHashMap 虽然也是 synchronized 但它是对链表或者红黑树的头节点进行加锁,锁的粒度更小 |
底层工作原理 | 底层采用的是 数组 + 链表 | ConcurrentHashMap JDK 1.7 底层采用 分段的数组 + 链表实现。 JDK 1.8 采用的是 数组 + 链表/红黑树 |
底层采用的是 数组 + 链表 |
空值问题 | HashMap允许使用null值(key和value)都可以。 但是这样的键只有一个,可以有一个或多个键所对应的值为null |
HashTable不允许null值(key和value都不可以) | |
初始容量、扩容与默认负载因子 | HashMap 默认初始大小 16,每次扩容 2n,默认负载因子是0。75 | HashTable 默认初始大小为11,每次扩容 2n+1 |
你都知道哪些常用的Map集合?
HashMap、HashTable、TreeMap、LinkedHashMap、ConcurrentHashMap
@RequestMapping 注解有什么用?
@RequestMapping
注解,用于将特定 HTTP 请求方法映射到将处理相应请求的控制器中的特定类/方法。此注释可应用于两个级别:
- 类级别:映射请求的 URL。
- 方法级别:映射 URL 以及 HTTP 请求方法。