Transaction And Lock--解决死锁/锁的几种有效方式

修改资源访问顺序,使多个事务对资源的访问方式一致
优化查询SELECT,使得S锁能尽早释放
均可能将更新和删除语句放到事务末端(使得X锁占用时间最小)
避免事务执行期间暂停或等待外部输入
将较大事务拆分成多个小事务提交
控制事务在合适的隔离级别上运行
建立合适索引提示语句效率
删除无用索引和统计
将数据更新修改为数据插入
将数据拆按状态分到多个表
考虑使用快照解决S锁阻塞X锁
考虑使用程序队列来限制并发数(高并发造成大量的锁等待和上下文切换以及CPU资源消耗)
使用复制等技术将读写分离
在程序段使用缓存来避免对相同数据频繁更新

posted on 2014-01-16 18:23  笑东风  阅读(603)  评论(0编辑  收藏  举报

导航