如何控制web程序中的并发行为

如何控制web程序中的并发行为,第1张

1、提供HTML静态访问

web界面上最快的访问速度是什么?当然是最原始的HTML文件访问,对于其他语言中迟衡 比如 jsp ,asp,php等等,他们首先要通过服务器解析成html之后在返回给访问者,如果我们能提供全部是htm来的页面,那么就能大大的降低服务器和数据库资源的利用和提高网站的并发,所以我们尽可能使我们的网站上的页面采用静态页面来实现,这个最简单的方法其实也是最有效的方法。当然实现这种方式大家比较了解的就是信息发布系统CMS,信息发布系统可以实现最简单的信息录入自动生成静态页面,还能具备频道管理、权限管理、自动抓取等功能,对于一个大型网站来说,拥有一套高效、可管理的CMS是必不可少的。

在后续的文章中我们会单独的使用jsp + servlet实现一个简单的信息发布系统.

2、使用独立的图片服务器

为什么要把图片单独设置一个服务器?对于Web服务器来说,图片消耗的服务器资源是最多的,如果能把所有的图片资源放到一个单独的图片服务器中进行处理的话,可以降低提供页面访问请求的服务器系统压力,从而能进一步的提高web程序的并发.所以在有条件的情况下最好能把图片放置到一个单独的服务器中.

3、配置多台数据库服务器,多个数据库集群

集群(Cluster)技术是使旦乱用特定的连接方式,将价格相对较低的硬件设备结合起来,同时也能提供高性能相当的任务处理能力。

越是大型高并发的应用,数据库的压力就会越大,如果数据库 *** 作很频繁,数据库的瓶颈很快就能显现出来,这时一台数据库将很快无法满足应用,于是我们需要使用卖做数据库集群。

数据库集群就是使用多个数据库服务器分担请求的压力,达到快速响应的目的.

4、使用缓存

所谓的缓存就是把数据咱是放置到内存中,前台在请求的时候直接从内存中读取数据,而不需要去查询数据库或者读取文件等,这样就能做到最快的响应。网站架构和网站开发中的缓存是非常重要的。

目前有很多开源的缓冲实现方案,APC,File,SQLite,Memcache等等各种类库实现着不同的缓存方式,只有通过了解他们的实现方式,根据具体应用具体选择,才会使缓存系统发挥出最大的性能。

对于java开发来说,大名顶顶的 分布式缓存系统Memcache 可能是最好的选择,他提供一个基于Socket的访问方式,使得该缓存系统支持远程读写访问。尽管这个缓存的内容可能是存在内存中,也可能是存在文件内。

分2分情况:

一.普通的单应用并发,使用关键字synchronized就可以实现。

二.多应用或多台并发,这时在由于2者并非同一应用消陆,使用synchronized并不能满足要求。此时,有下面几种方案:

数据库行级锁,优点是简单粗暴,缺点是容易死银闹锁,非数据库专业人事建议不使用。

写入请求分离成一个独立项目,这就回到了第一种情况,优点是实现技术难度低,缺点是高并发性能相对不是很高。

使用分布式事务管理,这个是目前高并发处理的最优方案拿搏顷了。

最后要说的没有差的方案,每个方案都有其适用环境,请根据自身需求选择对应方案。

并空基空发的意思就是有多人同时进行一个 *** 作, 比如你家大门 有两个人同时进去

这就叫并发了 要是一个人一个人排队进就不是并发, 要是 几百斗瞎上千上万人同时进大门 就可以称为锋岁高并发了

并发和高并发 其实意思是一样的 不同的只是并发数量上的区别

web的并发是指 多人同时向一个url发送请求


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12559915.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存