`
raymond2006k
  • 浏览: 296026 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

利用CAS原理处理修改操作的分布式事务控制

阅读更多
1. CAS
   CPU指令 和 程序并发原语中存在 CAS 概念, Compare and Set, 就是修改一个寄存器区域或变量值时,先检查 old value, old value相同再进行修改,否则放弃。
 
   例如:
   已知 int a = 1;
引用
   非 CAS 赋值为:  a = 10;
   CAS 赋值为   compareAndSet( 1, 10);

  这样,在多线程并发操作时,最终 a 将被原子性的修改,而不会发生冲突的结果。

   而数据库的事务中并发冲突的场景与之非常类似,都是对共享资源竞争访问时的突出问题。

2. 基于CAS机制的数据库update操作
   由CAS的原理,可以考虑以类似的方式处理数据库的update操作。

   假定订单 OD_0100 的总价款为1100 元, 现在要将其修改为 1500 元,

引用
   update sale_order set order_amount = 1500.00
   where order_id = 'OD_0100'


采用 CAS 机制进行修改,假定已经知道订单修改前的总价款 1100,则update SQL为
引用

   update sale_order set order_amount = 1500.00
   where order_id = 'OD_0100'
     and order_amount = 1100.00

  若出现并发冲突,例如:order_amount 已经先其他请求修改为 900, 那么上面的 update 语句的操作结果数为 0; 此时,客户端需要重新查询订单,再尝试第二次修改。 这类似于 CAS 中的自旋。

3. 与其他事务机制比较
  数据库事务有悲观锁和乐观锁,乐观锁有一种机制是基于 version 字段来控制并发修改冲突。
  与version事务机制类似,CAS事务也是一种细粒度的锁。然而,version 为行级锁,粒度过大; 而 CAS 事务为列级锁,粒度更小。 根据锁机制的一般原则,粒度越小,并发性能越高。

0
0
分享到:
评论
2 楼 dogstar 2010-12-15  
stm就是cas的库/语言级别的实现.
1 楼 mercyblitz 2010-05-28  
CAS 直接操作内存,性能很好。

按照个人的理解,多CPU通过并行控制主存的CAS操作,但为什么不能分离内存操作了,分布式内存,岂不是更好?

相关推荐

    浅谈CAS在分布式ID生成方案上的应用

    CAS的主要优势在于它能提供一种轻量级的并发控制机制,使得多线程环境下的数据操作更加高效和安全。尤其是在高并发场景下,相比于传统的锁机制,CAS可以显著减少线程间的等待时间,提高系统的整体吞吐量。 #### 四...

    分布式事务解决方案.docx

    ### 分布式事务解决方案 #### 一、基础知识 在探讨分布式事务解决方案之前,我们需要了解一些基本的概念和技术背景。 ##### 1....理解这些基础概念对于设计和实现健壮的分布式事务处理系统至关重要。

    汽车电控系统的“分布式”控制理念解析.pdf

    文章以宝马汽车的车窗升降机系统作为例子,详细解释了分布式控制理念在实际应用中的工作原理。宝马轿车的车窗升降系统由三个控制单元负责:脚部空间模块(FRM)、接线盒控制单元(JB)和便捷登车及起动系统(CAS)。...

    Java CAS 原理分析

    CAS操作可能会遇到ABA问题(即在两次比较之间,一个值可能被多次修改回到初始状态),这时可以考虑使用带有版本号的CAS或其他替代方案。 #### 七、结论 CAS作为多线程环境中不可或缺的一种同步机制,通过硬件层面...

    CAS原理和配置过程

    ### CAS原理详解 CAS(Central Authentication Service)是一种开放源代码的单点登录协议和服务实现,广泛应用于企业级应用系统中。其主要目的是提供一个统一的身份验证解决方案,使得用户只需要在一个地方进行登录...

    cas原理 webflow mvc ioc

    WebFlow是Spring框架的一部分,专门用于处理复杂的Web应用流程控制,如表单处理和状态机驱动的应用逻辑。在CAS服务器端,WebFlow负责管理登录流程,其配置主要在`/WEB-INF/login-webflow.xml`文件中进行。该文件定义...

    cas源码修改-登录页面

    在“cas源码修改-登录页面”这个主题中,我们将深入探讨如何定制CAS服务器的登录界面以满足特定需求。 首先,CAS的登录页面通常位于`/login`路径下,这是由CAS服务器的核心组件处理的。在源码中,这部分主要涉及到`...

    H3C_CAS虚拟机支持的操作系统

    根据提供的文件信息,本文将详细阐述H3C_CAS虚拟机支持的操作系统相关知识点。 首先,H3C_CAS是指H3C公司推出的虚拟化平台CAS(Cloud Access Software),该平台允许用户在虚拟化环境下部署和管理各种应用。H3C_CAS...

    DVB-CAS原理介绍.doc

    4. **CA的运行模式**:CAS系统可以有不同的运行模式,如集中式、分布式等,以适应不同的网络环境和业务需求。 5. **CAS系统应用模式**:根据不同的市场和运营策略,CAS系统可以有不同的应用模式,如集成在机顶盒内或...

    CAS实现原理与例子

    "CAS实现原理与例子" CAS(Central Authentication Service,中央认证服务)是一种单点登录(Single Sign-On,SSO)机制,允许用户在访问不同的应用系统时,只需要输入一次用户名和密码。CAS实现原理与例子主要包括...

    cas原理.doc

    总的来说,CAS原理涉及到的身份验证机制、TGT和ST的概念,以及Spring Webflow在实现登录流程中的作用,都是理解CAS工作方式的关键点。通过定制化Spring Webflow配置,开发者可以根据需求扩展或调整CAS的默认行为,以...

    cas单点才登出原理

    接下来,我们将详细探讨CAS单点登出的原理。 首先,理解SSO的基本流程: 1. 用户打开一个受CAS保护的应用系统A。 2. 应用系统A发现用户未登录,重定向到CAS服务器。 3. 用户在CAS服务器上输入凭证并验证通过。 4. ...

    CAS原理 java 并发

    **标题:“CAS原理与Java并发”** 在Java并发编程中,CAS(Compare and Swap,比较并交换)是一种无锁算法,广泛应用于多线程环境下的数据同步。它通过硬件指令来实现原子操作,提升了并发性能,同时避免了锁带来的...

    CAS 原理讲解

    ### CAS原理讲解 #### 一、引言与背景 CAS(Central Authentication Service)是一种开源的单点登录(Single Sign-On, SSO)协议及其实现,主要用于简化用户在多个应用程序和服务中的认证过程。它通过集中式的身份...

    cas修改登录页

    【标题】"CAS修改登录页"是一个针对中央认证服务(Central Authentication Service,简称CAS)的定制化实践。在单点登录(Single Sign-On,SSO)系统中,CAS扮演着核心角色,它提供了统一的身份验证服务,使得用户只...

    H3C 云计算CAS产品典型配置案例汇总集.rar

    H3C_CAS支持硬件SR-IOV操作指导书 H3C_CAS与趋势产品联调操作配置指导书 H3C_CAS虚拟机内存隔离操作指导书 H3C_CAS虚拟机搭建双机热备环境方案及报告 ) H3C_CAS_3.0虚拟机防病毒操作指导书 H3C_CAS端口镜像特性...

    深入探索Java中的CAS操作:原理、实现与应用

    在Java并发编程中,CAS(Compare-and-Swap)操作是一种关键的技术,它允许在无锁的情况下实现线程安全的数据操作。CAS操作通过比较内存中的值与预期值,如果相等,则原子地更新为新值。本文将详细介绍CAS的工作原理...

    CAS的原理分析

    CAS的原理分析

Global site tag (gtag.js) - Google Analytics