高并发的几个解决方法

web访问上

1 首页生成静态html

  一般我们写程序的时候,用户访问页面都是执行.do访问到后台返回响应的jsp,但像首页那种访问量大的页面,可以5分钟等做一次静态化,访问的时候直接返回响应的html页。

2 图片服务器和页面服务器分离

  不分离的话,html,jsp加载是按顺序加载,分离就可以同步加载,现在像微博的图片加载都是阿里给做的服务吧。

3 web服务器的负载均衡

  可以再多个tomcat上放个ngix服务器做负载,还有就是有用DNS串分流访问不同的tomcat,还有就是在web服务器上加上F5,F5可以根据web服务器的健康状况选择响应的服务器。

缓存

1 减少对查询数据库操作,减少数据库开关资源消耗。

2 可以把静态信息如图片等,常访问的数据放到Redis中。

数据库方面

1 读写分离 可以是双主,一个读,一个写,binlog做同步

2 水平分割 如果哪个表中记录较多,可以多建几个库,将该表中数据可以以一致性哈希的方式分布在多个库上

3 垂直分割 把关联关系弱的表放在不同的库中

4 索引

聚集索引 主要建在主键上 聚集的意思是索引在物理磁盘上是顺序排列的,像表中的记录一样

非聚集索引 主要像top10低效的查询语句,查询结果建索引,这个结果集在物理上是不挨着的

另外 索引建多了会占用空间 而且索引会影响更新操作的效率。

负载均衡

Web 数据库上

消息队列

多个并发的请求可以放在队列中 不重要的延时执行

CDN

就是将镜像服务器缓存服务器 负载均衡 多弄几套放在不同地区 不同地区不同的服务器响应 之间同步数据

全文检索 solr 检索数据时在solr上找到数据的位置。

 

 

高并发的处理:

        ① 配置多个Linux外部服务器,Nginx反向代理。

        ② 增加缓存服务器,将数据放入内存里面,增加读取速度。

        ③ 搭建Redis集群。

        ④ 做数据分离(建立历史表,用的技术是Quartz(每天定时定点的执行任务))。

        ⑤ 将逻辑处理涉及到多处数据库连接操作,优化成一个存储过程,只调用一次数据库,从而缩短数据库的访问时间。