前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >程序中的锁机制(二)

程序中的锁机制(二)

作者头像
蛋蛋编程手记
发布2022-12-12 21:15:40
3630
发布2022-12-12 21:15:40
举报
文章被收录于专栏:蛋蛋编程手记蛋蛋编程手记

具体到实际开发过程中,主要是以下三大类的锁,包括编程语言锁,数据库锁,分布式锁。

编程语言锁这里只谈java中的锁,因为蛋蛋主要用java来做开发。java中有synchronized关键字和lock接口两种加锁方式。

lock接口是java并发包提供的锁接口,它的实现类提供了丰富的加锁当时,使用起来比synchronized关键字更加的灵活,也是收到开发者的追捧。

当然synchronized也有它存在的价值。首先它使用简单方便;其次底层具体加锁原理随着jdk的不断升级而有了非常多的优化,性能也越来越好。 ​

数据库锁这里只说mysql数据库,而且是innodb存储引擎提供的锁。主要有表级锁和行级锁。

当对非索引字段加锁的时候,使用的是表级锁。当对索引字段加锁的时候,使用的是行级锁(如果数据库自身的优化导致不使用索引,那也是表级锁)。

行级锁也分记录锁、间隙锁。并非一定是单条记录锁,只有等值查询命中唯一索引才是锁住单条记录。其他情况锁住的都是一个范围。

分布式锁应用在分布式系统获取共享资源访问权限的时候,因为系统是分布式的,所以加锁的方式也需要改成分布式锁。常见的分布式锁实现方案有,数据库唯一索引机制,zookeeper临时节点机制,redis的setnx机制。

分布式系统本身就是一个复杂的应用,需要考虑方方面面的点。针对不同的加锁场景,有人要考虑以下的几个问题,从而选择合适的加锁方案。

1. 锁是否可重入

2. 锁怎么释放

3. 加锁解锁操作的原子性

4. 加锁失败怎么处理

5. 锁服务的高可用问题 ​

今日份总结:程序中的锁是保证程序中数据一致性的基础设施,不同的场景使用不同的加锁方案

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-11-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 蛋蛋编程手记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档