当前位置:首页 > 科技  > 软件

使用隔离层级和重试机制,Spring Boot轻松实现高并发

来源: 责编: 时间:2024-01-08 09:18:05 300观看
导读高并发难题高并发是开发者面临的一项挑战。使用Read Uncommitted隔离层级和重试机制,可以大幅提高系统的性能。在高并发系统中,锁异常始终是一个问题。多名用户或进程同时访问常常导致资源的争用,导致锁冲突,并导致异常和

高并发难题

高并发是开发者面临的一项挑战。使用Read Uncommitted隔离层级和重试机制,可以大幅提高系统的性能。aP628资讯网——每日最新资讯28at.com

在高并发系统中,锁异常始终是一个问题。多名用户或进程同时访问常常导致资源的争用,导致锁冲突,并导致异常和性能瓶颈。该问题不仅会打断开发流程,还会妨碍用户体验。解决这个问题对于确保流畅的、无中断的服务至关重要,同时优化资源利用率,面对不断增加的高并发应用的需求。aP628资讯网——每日最新资讯28at.com

解决方案

锁异常是处理大量写操作和事务时最常见的异常。接下来,我们使用乐观锁来解决这个问题。aP628资讯网——每日最新资讯28at.com

Spring Boot中的乐观锁是一种确保多用户环境中数据完整性的并发控制机制。它支持多个客户端同时读取和更新数据,同时最小化冲突。这是通过将版本号或时间戳与数据库中的每条记录相关联来实现的。当客户端更新记录时,将检查版本号以检测自数据最初读取以来,其他客户端是否对其进行了更改。如果检测到冲突,系统可以通过回滚事务并抛出异常来处理它,这个异常可以用于重试尝试。乐观锁是Spring Boot的JPA(Java 持久化 API)的关键功能,用于以安全和高效的方式管理数据库记录。aP628资讯网——每日最新资讯28at.com

首先,我们需要在实体中添加由spring boot管理的列,如下面的代码所示。aP628资讯网——每日最新资讯28at.com

@Entity@Datapublic class YourEntity {    @Id    @GeneratedValue    private Long id;    // 其他字段    @Version    private Long version; // 乐观锁版本列}

在上面的代码注释中,当对特定行进行更新时,@Version会自动更改版本号。所以,处理此行的其他事务会发现版本号已经更改,并将引发异常。我们可以捕获此异常来重试事务,如下代码所示。aP628资讯网——每日最新资讯28at.com

@Servicepublic class MyService {    @Autowired    private YourEntityRepository yourEntityRepository; // 假设有实体仓库    @Transactional(isolation = Isolation.READ_UNCOMMITTED)    @Retryable(        value = {OptimisticLockingException.class},        maxAttempts = 3,        backoff = @Backoff(delay = 200))    public YourEntity yourBusinesslogicTransactionMethod(Long entityId) {        YourEntity entity = yourEntityRepository.findById(entityId).orElse(null);                if (entity == null) {            throw new EntityNotFoundException("Entity with ID " + entityId + " not found.");        }        // 更新数据        entity.setName("UpdatedName");        // 存储到数据库        try {            yourEntityRepository.save(entity); // not using native query, only using default JPA methods        } catch (OptimisticLockingException ex) {            // 如果出现乐观锁异常,则表示发生了并发更新。            // @Retryable注释将触发指定次数的重试。            throw ex;        } catch (Exception ex) {            // 处理其他异常        }        return entity;    }}

在上面代码中,我们捕获异常,如果发现锁异常,则重试事务。隔离层级通常与事务性注释一起使用。aP628资讯网——每日最新资讯28at.com

Spring Boot中的隔离层级通过定义并发事务所做更改的可见性来控制数据库系统中的事务如何相互交互。隔离层级包括如下类型:aP628资讯网——每日最新资讯28at.com

READ_UNCOMITTED:支持读取其他事务未提交的更改,提供最小的隔离。aP628资讯网——每日最新资讯28at.com

READ_COMMITTED:支持只读取已提交的更改,防止脏读取。aP628资讯网——每日最新资讯28at.com

REPEATABLE_READ:确保在当前事务完成之前,其他事务的更改不可见,从而消除不可重复的读取。aP628资讯网——每日最新资讯28at.com

SERIALIZABLE:提供与其他事务的完全隔离,防止对数据的任何并发访问。aP628资讯网——每日最新资讯28at.com

READ_UNCOMITTED隔离层级提供了最高的并发性。因此,在上面的代码中,我们首先读取一行,然后尝试更新该行,在更新过程中,如果值发生了更改,JPA将检查版本列,这意味着在我们读取后,其他写入操作也更改了值。JPA在版本号更改时抛出锁异常。我们捕获此异常并重试事务。下次事务将读取更新后的值。aP628资讯网——每日最新资讯28at.com

在Retry注释的帮助下,我们可以轻松配置重试策略,如重试尝试、重试尝试和尝试重试的异常之间的持续时间。aP628资讯网——每日最新资讯28at.com

代码分析

版本注释与JPA默认查询完美配合。因此,在读取和更新期间,请尝试使用默认的JPA查询,不要使用本机查询。如果使用本机查询,则需要自己更新版本列数据。aP628资讯网——每日最新资讯28at.com

当请求数量非常高,而每行的并发请求较少时,这种方法非常好。在例子中,我们没有每行的高并发性。对于一行,并发请求的可能性几乎为零,但我们仍然得到了锁异常,因为我们没有指定任何隔离级别,默认隔离级别是READ_COMMITTED。aP628资讯网——每日最新资讯28at.com

乐观锁在不确定数据库锁行为的情况下很有价值。不用依赖数据库的锁定机制,而是在应用程序代码中处理数据并发冲突。aP628资讯网——每日最新资讯28at.com

在乐观锁中,只有正在更新的行被锁定,而不是整个表。当事务更新一行时,通常会增加与该行相关的版本号或时间戳,并且在更新过程中,会检查版本或时间戳。如果另一个事务同时修改了同一行,则会检测到并发冲突,您可以根据需要进行处理。aP628资讯网——每日最新资讯28at.com

乐观锁不会自动锁定相邻行或多行。它的设计目的是通过只锁定特定更新操作中涉及的行来最大限度地减少对并发访问的影响。其他事务可以继续读取或修改同一表中不相关的行,而不会被阻止。aP628资讯网——每日最新资讯28at.com

根据事务和数据库系统的隔离级别,带有WHERE子句的读取查询可能会锁定行。但是,确切的锁定行为会根据所使用的隔离级别而有所不同。在乐观的锁定场景中,重要的是要仔细考虑隔离级别,以最大限度地降低阻塞其他事务的风险。aP628资讯网——每日最新资讯28at.com

总结

优化高并发任务时,策略方法是必不可少的。在Spring Boot应用程序中,可利用隔离层级并采用高效的重试机制以及乐观锁,在性能和数据完整性之间取得平衡。aP628资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-57933-0.html使用隔离层级和重试机制,Spring Boot轻松实现高并发

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 算法江湖:揭秘分布式框架下的四大高手

下一篇: 使用Pytorch构建图卷积网络预测化学分子性质

标签:
  • 热门焦点
  • 女孩租房开2小时空调用完100元电费引热议:5级能耗惹不起 月薪过万电费也交不起

    近日,江苏苏州一女孩租房当天充值了100元电费,开着空调不到2小时发现电费已用完。对于为什么这个快,房东表示,电表坏了这种情况很多,之前也遇到过,给租客换
  • K6:面向开发人员的现代负载测试工具

    K6 是一个开源负载测试工具,可以轻松编写、运行和分析性能测试。它建立在 Go 和 JavaScript 之上,它被设计为功能强大、可扩展且易于使用。k6 可用于测试各种应用程序,包括 Web
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 这款新兴工具平台,让你的电脑效率翻倍

    随着信息技术的发展,我们获取信息的渠道越来越多,但是处理信息的效率却成为一个瓶颈。于是各种工具应运而生,都在争相解决我们的工作效率问题。今天我要给大家介绍一款效率
  • 重估百度丨“晚熟”的百度云,能等到春天吗?

    ©自象限原创作者|程心排版|王喻可2016年7月13日,百度云计算战略发布会在北京举行,宣告着百度智能云的正式启程。彼时的会场座无虚席,甚至排队排到了门外,在场的所有人几乎都
  • 微博大门常打开,迎接海外画师漂洋东渡

    作者:互联网那些事“起猛了,我能看得懂日语了”。“为什么日本人说话我能听懂?”“中文不像中文,日语不像日语,但是我竟然看懂了”…&hell
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • Windows 11发布,微软一改往常对老机型开放的态度

    距离 Windows 11 发布已经过去一周,在过去一周里,很多数码爱好者围绕其对 Android 应用的支持、对老机型的升级问题展开了激烈讨论。与以往不同的是,在这次大
  • 荣耀Magic4 至臻版 首创智慧隐私通话 强劲影音系统

    2022年第一季度临近尾声,在该季度内,许多品牌陆续发布自己的最新产品,让大家从全新的角度来了解当今的手机技术。手机是电子设备中,更新迭代十分迅速的一款产品,基
Top