>  기사  >  여러 스레드를 통해 동일/유사한 데이터베이스 작업을 동시에 수행할 수 있는 솔루션이 있습니까?

여러 스레드를 통해 동일/유사한 데이터베이스 작업을 동시에 수행할 수 있는 솔루션이 있습니까?

WBOY
WBOY앞으로
2024-02-22 12:31:06608검색

PHP 편집자 Zimo가 전하는 Java Q&A: 여러 스레드가 동시에 동일/유사한 데이터베이스 작업을 수행할 수 있도록 하는 솔루션이 있습니까? 개발 과정에서 데이터베이스를 동시에 운영하는 여러 스레드를 어떻게 효과적으로 처리할 것인가에 대한 문제는 항상 많은 관심을 끌었습니다. 이 기사에서는 개발자가 이 문제를 해결하는 데 도움이 되는 데이터베이스 연결 풀 사용, 잠금 메커니즘, 트랜잭션 처리 및 기타 방법을 포함한 여러 솔루션을 소개합니다. 시스템 성능과 안정성을 향상시키기 위해 다중 스레드 동시 데이터베이스 작업을 구현하는 방법을 살펴보겠습니다.

질문 내용

Java, Spring Boot 및 Hibernate를 사용하면 교착 상태나 오래된 데이터 예외를 발생시키지 않고 여러 스레드가 특정 작업을 동시에 수행할 수 있는 방법이 있습니까?

예를 들어, 자동화된 도구가 동시에 두 번 로그인하여 다음 상황 중 하나가 발생한다고 가정합니다.

  1. 두 개의 스레드(요청)가 동시에 사용자 기록을 업데이트하기 때문에 교착 상태가 발생합니다(예: 사용자의 마지막 로그인 날짜/시간 저장).
  2. 다른 스레드의 트랜잭션이 완료되기 전에 한 스레드가 사용자를 업데이트했기 때문에 오래된 데이터 예외가 발생했습니다.

이 문제는 사용자 ID에 동기화를 추가하면 해결될 수 있지만 그런 일은 어디서나 일어나야 하므로 잠재적인 성능 저하가 발생하고 코드베이스가 더 비대해지고 유지 관리가 어려워집니다.

또는 격리 수준을 조정할 수 있습니다(기본 수준을 전역적으로 설정할 수도 있음). 이것이 더 나은 솔루션입니까, 아니면 다른 솔루션이 있습니까?

Solution

비관적 잠금.

트랜잭션 초기에 업데이트해야 할 수 있는 모든 행을 잠급니다. 읽기 잠금을 사용하여 이 작업을 수행할 수 있습니다.

으아악

한 스레드만 얻을 수 있습니다. 다른 스레드는 이 스레드가 잠금을 해제할 때까지 기다립니다.

그동안 잠금을 유지하는 스레드는 준비가 되면 행을 업데이트할 수 있습니다.

으아악

그럼 다른 스레드에 대한 예의를 위해 update 이후 최대한 빨리 제출해 주시기 바랍니다. 그러면 자동으로 잠금이 해제됩니다.

으아악

이를 통해 대기 중인 다음 스레드가 기다리고 있는 잠금을 획득할 수 있습니다.

잠금 읽기를 사용하여 여러 행, 심지어 여러 테이블의 여러 행을 잠글 수 있습니다. select 쿼리로 확인한 모든 행은 잠깁니다. 여러 테이블의 행을 잠가야 하는 경우 조인과 같은 작업을 수행할 수 있습니다.

잠금 획득은 원자적이므로 주어진 잠금 문은 요청된 모든 잠금을 획득해야 하며, 그렇지 않으면 기다려야 합니다.

위 내용은 여러 스레드를 통해 동일/유사한 데이터베이스 작업을 동시에 수행할 수 있는 솔루션이 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제