c# – 在服务器场上锁定(asp.net)

我想知道是否有任何方法可以使用像MySQL Cluster这样的分布式服务器在部署在多个服务器上的asp.net Web应用程序上执行“锁定”.

例如,采用更新帐户余额的经典示例.没有两个请求应该同时更新相同的帐户余额.例如:

会员1帐户余额为100.

>请求A访问服务器1以向成员1的余额添加100
>请求B访问服务器2以将50添加到成员1的余额

因此,请求A将余额从100更新为200并保存.
请求B将余额更新为150,并保存.

这些都恰好同时发生,因此丢失信息,因为最终结果应该是250.

如何锁定,使得请求B必须等到请求A完成,直到它检索到余额.如果是单个进程,则可以通过应用程序范围的锁实现.但是,由于存在多个独立进程,因此不会像服务器1那样工作,因为它没有被锁定,也没有服务器2

任何想法或最佳实践如何做到这一点?

解决方法:

这就是交易的目的.

TransactionScope中包含需要为atomic的操作,以将它们注册到显式事务中.

这并不能完全解决陈旧数据的问题,因为一旦事务完成,如果另一个并发用户使用旧值进行更新,您仍然会遇到问题.

解决方案是在表上使用一个字段,该字段在行更改时会发生更改 – 在SQL Server 2008中,这是rowversion类型.

如果rowversion未更改,则只更新行 – 如果有,则通知用户并在不进行更新的情况下恢复当前值.

上一篇:使用Spring Cache Abstraction和JDBC DAO进行交易


下一篇:Swing应用程序在Apple Java更新1.6.0_51之后停滞不前