SpringMVC是单例的,高并发情况下,如何保证性能的?
来源:互联网 发布:淘宝网儿童冬季服装 编辑:程序博客网 时间:2024/05/16 19:39
首先在大家的思考中,肯定有影响的,你想想,单例顾名思义:一个个排队过... 高访问量的时候,你能想象服务器的压力了... 而且用户体验也不怎么好,等待太久~
实质上这种理解是错误的,Java里有个API叫做ThreadLocal,spring单例模式下用它来切换不同线程之间的参数。用ThreadLocal是为了保证线程安全,实际上ThreadLoacal的key就是当前线程的Thread实例。单例模式下,spring把每个线程可能存在线程安全问题的参数值放进了ThreadLocal。这样虽然是一个实例在操作,但是不同线程下的数据互相之间都是隔离的,因为运行时创建和销毁的bean大大减少了,所以大多数场景下这种方式对内存资源的消耗较少,而且并发越高优势越明显。
总的来说就是,单利模式因为大大节省了实例的创建和销毁,有利于提高性能,而ThreadLocal用来保证线程安全性。
另外补充说一句,单例模式是spring推荐的配置,它在高并发下能极大的节省资源,提高服务抗压能力。spring IOC的bean管理器是“绝对的线程安全”。
另外补充说一句,单例模式是spring推荐的配置,它在高并发下能极大的节省资源,提高服务抗压能力。spring IOC的bean管理器是“绝对的线程安全”。
阅读全文
0 0
- SpringMVC是单例的,高并发情况下,如何保证性能的?
- SpringMVC是单例的,高并发情况下,如何保证性能的?
- SpringMVC是单例的,高并发情况下,如何保证性能的?
- SpringMVC是单例的,高并发情况下,如何保证性能的?
- SpringMVC默认单例的,高并发情况下,如何保证性能的?
- 如何处理高并发情况下的DB插入
- 如何处理高并发情况下的DB插入
- 如何处理高并发情况下的DB插入
- 如何处理高并发情况下的DB插入
- 高并发情况下 如何支撑大量的请求
- 高并发高负载情况下常见的3种性能问题
- 高并发高负载情况下常见的3种性能问题
- 高并发高负载情况下常见的3种性能问题
- 高并发高负载情况下常见的3种性能问题
- 简述如何提高单机下服务器的高并发性能
- 使用Google的开源TCMalloc库,提高MySQL在高并发情况下的性能
- 使用Google的开源TCMalloc库,提高MySQL在高并发情况下的性能
- 使用Google的开源TCMalloc库,提高MySQL在高并发情况下的性能
- Sagheer and Nubian Market
- stopPropagation() 和 preventDefault() 事件
- c++ 类静态变量 类常变量Mark
- linux mysql 报错ERROR 1820 (HY000): You must SET PASSWORD before executing this statement
- Android NDK 第一行代码
- SpringMVC是单例的,高并发情况下,如何保证性能的?
- 我的博客
- Centos7中openvpn搭建
- this*到底在哪里定义
- 安装SQL Server 2017卡死,一直卡在一个界面很久不动的解决方案
- Android自定义ViewGroup实现水平排列样式(1)
- Redis 数据类型及应用场景
- 如何让自己的程序在开机时自动启动
- 测试用的博客