>데이터 베이스 >MySQL 튜토리얼 >비관적 잠금과 낙관적 잠금의 정의

비관적 잠금과 낙관적 잠금의 정의

hzc
hzc원래의
2020-07-02 16:07:194955검색

비관적 잠금은 이름에서 알 수 있듯이 배타적이고 배타적인 특성이 강합니다. 외부 세계에 의해 수정되는 데이터에 대한 보수적인 태도를 의미합니다. 낙관적 잠금 메커니즘은 비관적 잠금과 비교하여 보다 완화된 잠금 메커니즘을 채택하며 데이터베이스 팬텀 읽기, 긴 비즈니스 처리 시간 및 기타 이유로 인해 발생하는 데이터 처리 오류를 방지하는 메커니즘이기도 합니다.

비관적 잠금과 낙관적 잠금의 정의

낙관적 잠금(Optimistic Locking)

낙관적 잠금은 비관적 잠금과 관련이 있으며, 낙관적 잠금은 일반적인 상황에서는 데이터가 충돌을 일으키지 않는다고 가정하므로 데이터가 제출될 때만 공식적으로 업데이트됩니다. 데이터에 충돌이 있는지 감지합니다. 충돌이 발견되면 사용자가 무엇을 할지 결정할 수 있도록 오류 메시지가 사용자에게 반환됩니다.

Baidu 백과사전:
낙관적 잠금 메커니즘은 보다 완화된 잠금 메커니즘을 채택합니다. 낙관적 잠금은 비관적 잠금과 관련된 메커니즘이기도 하며, 데이터베이스의 팬텀 읽기와 긴 비즈니스 처리 시간으로 인해 발생하는 데이터 처리 오류를 방지하기 위한 메커니즘이기도 합니다. 그러나 낙관적 잠금은 데이터베이스 자체의 잠금 메커니즘을 의도적으로 사용하는 것이 아니라, 데이터의 정확성을 보장하기 위해 데이터 자체에 의존합니다.

비관적 잠금과 비교하여 낙관적 잠금은 데이터베이스를 처리할 때 데이터베이스가 제공하는 잠금 메커니즘을 사용하지 않습니다. 낙관적 잠금을 구현하는 일반적인 방법은 데이터 버전을 기록하는 것입니다.

비관적 잠금과 낙관적 잠금의 정의

낙관적 동시성 제어는 트랜잭션 간의 데이터 경합 확률이 상대적으로 작다고 생각하므로 최대한 직접적으로 진행하고 제출할 때까지 잠그지 않으므로 잠금 및 교착 상태가 발생하지 않습니다.

비관적 잠금

데이터베이스의 데이터 일부를 수정하려는 경우 다른 사람이 동시에 수정하는 것을 방지하기 위해 가장 좋은 방법은 데이터를 직접 잠가서 동시성을 방지하는 것입니다. 데이터베이스 잠금 메커니즘을 사용하여 데이터를 수정한 다음 수정하기 전에 데이터를 잠그는 이 방법을 비관적 동시성 제어["비관적 잠금", 비관적 동시성 제어, 약어로 "PCC"라고도 함]라고 합니다.

Baidu 백과사전:
비관적 잠금은 이름에서 알 수 있듯이 강력한 배타성과 배타적 특성을 가지고 있습니다. 이는 외부 세계에 의해 수정되는 데이터(시스템의 다른 현재 트랜잭션 및 외부 시스템에서 처리되는 트랜잭션 포함)에 대한 보수적인 태도를 의미합니다. 따라서 전체 데이터 처리 프로세스 동안 데이터는 잠금 상태로 유지됩니다. 비관적 잠금의 구현은 데이터베이스에서 제공하는 잠금 메커니즘에 의존하는 경우가 많습니다(데이터베이스 계층에서 제공하는 잠금 메커니즘만이 데이터 액세스의 배타성을 실제로 보장할 수 있습니다. 그렇지 않으면 이 시스템에 잠금 메커니즘이 구현되어 있어도 잠금 메커니즘이 없습니다). 외부 시스템이 데이터를 수정하지 않도록 보장합니다.

비관적 잠금이라고 불리는 이유는 데이터 수정에 대해 비관적인 태도를 갖는 동시성 제어 방법이기 때문입니다. 우리는 일반적으로 데이터가 동시에 수정될 확률이 상대적으로 높다고 생각하므로 수정 전에 데이터를 잠글 필요가 있습니다.

비관적 잠금은 크게 공유 잠금과 배타적 잠금으로 구분됩니다

  • 공유 잠금 [공유 잠금]은 읽기 잠금, 줄여서 S 잠금이라고도 합니다. 이름에서 알 수 있듯이 공유 잠금은 여러 트랜잭션이 동일한 데이터에 대한 잠금을 공유할 수 있고 모두 데이터에 액세스할 수 있지만 읽기만 가능하고 수정할 수 없음을 의미합니다.

  • 독점 잠금 [독점 잠금]은 쓰기 잠금, 줄여서 X 잠금이라고도 합니다. 이름에서 알 수 있듯이 배타적 잠금은 다른 잠금과 공존할 수 없습니다. 트랜잭션이 데이터 행에 대해 배타적 잠금을 획득하면 다른 트랜잭션은 더 이상 공유 잠금 및 배타적 잠금을 포함하여 해당 행에 대한 다른 잠금을 획득할 수 없습니다. 잠금은 데이터 행을 읽고 수정할 수 있습니다.

비관적 동시성 제어는 실제로 데이터 처리의 보안을 보장하는 "먼저 잠금을 얻은 다음 액세스"하는 보수적인 전략입니다.

비관적 잠금과 낙관적 잠금의 정의

그러나 효율성 측면에서 잠금 메커니즘은 데이터베이스에 추가 오버헤드를 발생시키고 교착 상태 가능성을 높입니다. 또한 트랜잭션이 데이터 행을 잠그면 다른 트랜잭션은 해당 데이터 행을 처리하기 전에 트랜잭션이 처리될 때까지 기다려야 합니다.

위 내용은 비관적 잠금과 낙관적 잠금의 정의의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.