我想知道是否有任何方法可以使用像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未更改,则只更新行 – 如果有,则通知用户并在不进行更新的情况下恢复当前值.