OrientDB-캐싱

Caching사용자 애플리케이션에 편안한 환경을 제공하는 데이터베이스 테이블 구조의 사본을 작성하는 개념입니다. OrientDB에는 다양한 수준의 여러 캐싱 메커니즘이 있습니다.

다음 그림은 캐싱이 무엇인지에 대한 아이디어를 제공합니다.

위 그림에서 DB1, DB2, DB3 응용 프로그램에서 사용되는 세 가지 데이터베이스 인스턴스입니다.

Level-1 캐시는 Local cache특정 세션에 알려진 모든 엔티티를 저장합니다. 이 세션에 3 개의 트랜잭션이있는 경우 3 개의 트랜잭션에서 사용되는 모든 항목이 보관됩니다. 이 캐시는 세션을 닫거나 "지우기"방법을 수행 할 때 지워집니다. 응용 프로그램과 데이터베이스 간의 I / O 작업 부담을 줄이고 성능을 향상시킵니다.

Level-2 캐시는 Real cache타사 공급자를 사용하여 작동합니다. 캐시의 내용을 완전히 제어 할 수 있습니다. 즉, 제거 할 항목, 더 오래 저장해야하는 항목 등을 지정할 수 있습니다. 여러 스레드 간의 전체 공유 캐시입니다.

Storage model 디스크, 메모리 또는 원격 서버 인 저장 장치 일뿐입니다.

OrientDB에서 캐시는 어떻게 작동합니까?

OrientDB 캐싱은 다양한 환경에서 다양한 방법론을 제공합니다. 캐싱은 주로 빠른 데이터베이스 트랜잭션에 사용되어 트랜잭션 처리 시간을 줄이고 성능을 향상시킵니다. 다음 흐름도는 로컬 모드와 클라이언트-서버 모드에서 캐싱이 작동하는 방식을 보여줍니다.

로컬 모드 (내장 데이터베이스)

다음 순서도는 레코드가 로컬 모드에서 스토리지와 사용 된 애플리케이션 사이에있는 방법 (예 : 데이터베이스 서버가 로컬 호스트에있을 때)을 보여줍니다.

클라이언트 응용 프로그램이 레코드를 요청할 때 OrientDB는 다음 사항을 확인합니다.

  • 트랜잭션이 시작된 경우 트랜잭션 내부에서 변경된 레코드를 검색하고 발견되면 반환합니다.

  • 로컬 캐시가 활성화되고 요청 된 레코드가 포함 된 경우이를 반환합니다.

  • 이 시점에서 레코드가 캐시에 없으면 저장소 (디스크, 메모리)에 요청합니다.

클라이언트 서버 모드 (원격 데이터베이스)

다음 순서도는 클라이언트-서버 모드에서 즉, 데이터베이스 서버가 원격 위치에있을 때 레코드가 스토리지와 사용 된 애플리케이션 사이에있는 방법을 보여줍니다.

클라이언트 응용 프로그램이 레코드를 요청할 때 OrientDB는 다음 사항을 확인합니다.

  • 트랜잭션이 시작된 경우 트랜잭션 내부에서 변경된 레코드를 검색하고 발견되면 반환합니다.

  • 로컬 캐시가 활성화되고 요청 된 레코드가 포함 된 경우이를 반환합니다.

  • 이 시점에서 레코드가 캐시에 없으면 TCP / IP 호출을 통해 서버에 레코드를 요청합니다.

  • 서버에서 로컬 캐시가 활성화되고 요청 된 레코드가 포함 된 경우 반환합니다.

  • 이 시점에서 여전히 레코드는 서버에 캐시되지 않고 스토리지 (디스크, 메모리)에 요청합니다.