Realm Instance는 thread safe하지 않으며, Realm에서 조회된 object 역시 thread safe하지 않다. Realm은 성능을 위해 무복제 아키텍쳐로 설계 되어 있다. 간단히 말하자면 realm에서 조회된 object는 단순히 database에서 복제된 data가 아니라 core database에 직접 연동되어 있다. 그렇기 때문에 조회된 object를 변경하면 database와 이미 조회된 다른 object들에 라이브로 자동 갱신된다.
일반적으로 multi threading 환경에서 critical section을 보호하기 위해서 Lock을 사용하는데, 이는 병목 현상의 원인이 됨으로 realm에서는 lock을 지원하지 않는다. 따라서 조회된 하나의 object에 여러 thread들이 접근하게 되면 문제가 발생하게 됨으로 만약 다른 thread에서 같은 데이터가 필요하면 그 thread에서 realm instance를 하나 더 만들고 object를 다시 조회해야 한다.
무복제 아키텍쳐인 Realm은 ACID를 보장하기 위해서 Lock이 아닌 MVCC(multiversion concurrency control)를 기반으로 설계되어 있다. [그림 1] 처럼 조회된 object A가 변경이 있을때, realm은 스냅샷을 찍고 v2를 만들어 object가 해당 버전을 바라보게 만든다. 이때 다른 thread들이 A를 접근하게 되면 v1를 조회하게 된다. 서로 다른 버전을 조회하고 변경함으로 ACID를 보장할 수 있게 된다.
'iOS' 카테고리의 다른 글
Swift에서의 DI(Dependency Injection) (0) | 2020.08.11 |
---|---|
Swift에서의 AOP (0) | 2020.08.03 |
SwiftUI Bata 하루 사용해본 후기 (0) | 2019.08.17 |