java高并发,如何解决,什么方式解决,高并发

java高并发,如何解决,什么方式解决,高并发,第1张

首先,为防止高并发带来的系统压力,或者高并发带来的系统处理异常,数据紊乱,可以以下几方面考虑:1、加锁,这里的加锁不是指加java的多线程的锁,是指加应用所和数据库锁,应用锁这边通常是使用redis的setnx来做,其次加数据库锁,因为代码中加了应用所,所以数据库不建议加悲观锁(排他锁),一般加乐观锁(通过设置一个seq_no来解决),这两个锁一般能解决了,最后做合理的流控,丢弃一部分请求也是必不可少的

Java开发高并发的处理方法:

最基础的地方做起,优化我们写的代码,减少必要的资源浪费

避免频繁的使用new对象,对于整个应用只需要存在一个实例的类,我们可以使用单例模式。对于String连接 *** 作,使用      StringBuffer或StringBuilder,对于工具类可以通过静态方法来访问。

避免使用错误的方式,尽量不用instanceof做条件判断。使用java中效率高的类,比如ArrayList比Vector性能好。

服务器分离

对于web服务器来说,是最消耗资源的,于是我们有必要把与页面进行分离,我们把放到独立的服务器。这样的架构可以降低提供页面访问请求的服务器系统压力,并且可以保证系统不会因为的问题而崩溃。在服务器上,我们可以对不同的配置进行优化。

缓存

具体接触过的缓存机制是hibernate的缓存机制。为了避免每次都向数据库中取得数据,我们把用户常常访问到的数据放到内存中,甚至缓存十分大的时候我们可以把内存中的缓存放到硬盘中。还有高级的分布式缓存数据库使用,都可以增加系统的抗压力。

分批传送

在做某项目的时候,一次传递的参数太多,而且数据库规定一次最多传递的参数最多是三万条,当时有五万条记录,那怎么传送呢?最终是分批传送,电梯里一次乘不下那么多的人,会报超重的bug,那就分批把人送上去。

还有一次在考试系统中,如果那么多的考试人员同时提交到数据库中,数据库的压力增大,有时会被down掉,当时采用的方法是使用ajax异步传输,没有等待考生点击提交按钮的时候,就把考生的答案自动提交,这样也避免了突然断电考生前面做过的题出现丢失的现象。

DB优化

在数据库设计的时候就要考虑到后期的维护,数据库三范式是我们设计数据库索要遵循的原则。

索引的建立:建立索引要适当,如果一个表经常用来被查询,对于增加和修改很少被用到,我们就可以为这个表建立索引,因为对于增加和修改和删除 *** 作时,我们对索引的维护要大大超过索引给我们带来的效率。

表字段的类型选择要恰当。包括字段的长度、类型等,要根据实际存储的数据进行选择,长度不要过长,否则会影响效率。

外键要慎用,因为主键代表这一张表,而外键代表一群表,对表之间进行了关联,在删除修改等需要我们关联。

在数据库 *** 作上。 尽量使用prepareStatement,少用Statement,因为PrepareStatement是进行预编译的。

connection设置为readOnly,Connection是对书库连接,属于重量级,我们使用即可。

连接池的使用,我们可以修改数据库默认的连接数。

如果遇到这个问题了有一个办法可以实现你的要求将读取存储过程的代码块加锁达到线程安全就OK了

怎么会呢

每个对象都只有一个锁标记,只有获得锁标记的进程才能执行里面的代码

不是几核的问题CPU看似可以处理很多请求其实一个时刻也只能处理一个请求因为它的速度相当快所以我们就觉得它是一次处理很多请求

以上就是关于java高并发,如何解决,什么方式解决,高并发全部的内容,包括:java高并发,如何解决,什么方式解决,高并发、面试Java开发时问到高并发怎么处理的,还有sql优化有哪些办法,有哪位大神知道啊,新手!!、为什么Java程序在并发的情况下数据库会出现重复记录等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/sjk/9495908.html

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

发表评论

登录后才能评论

评论列表(0条)

保存