Datastore 모드로 Cloud Firestore 사용

Firestore는 자동 확장, 고성능, 간편한 애플리케이션 개발을 위해 설계된 NoSQL 문서 데이터베이스입니다. Datastore의 최신 버전이며 Datastore에 비해 여러 가지 부분이 개선되었습니다.

Datastore 모드의 Firestore는 서버 사용 사례 및 App Engine에 최적화되어 있으므로 App Engine 앱에서 주로 사용하는 데이터베이스에는 Datastore 모드의 Firestore를 사용하는 것이 좋습니다. 기본 모드의 Firestore는 모바일 및 실시간 알림 사용 사례에 가장 유용합니다. Firestore 모드에 대한 자세한 내용은 Native 모드와 Datastore 모드 중 선택을 참조하세요.

이 문서에서는 Google Cloud 클라이언트 라이브러리를 사용하여 Datastore 모드 데이터베이스에서 데이터를 저장하고 검색하는 방법을 설명합니다.

기본 요건 및 설정

App Engine에서 PHP용 'Hello, World!'의 안내에 따라 환경과 프로젝트를 설정하고 PHP 앱이 App Engine에서 구조화되는 방식을 이해합니다. 프로젝트 ID를 기록하여 보관하세요. 이 문서에서 설명하는 샘플 애플리케이션을 실행하는 데 필요합니다.

저장소 복제

샘플을 다운로드(복제)합니다.

git clone https://github.com/GoogleCloudPlatform/php-docs-samples
cd php-docs-samples/appengine/flexible/datastore

프로젝트 구성 수정 및 종속 항목 설정

Composer를 사용하여 종속 항목을 설치합니다.

composer install

애플리케이션 코드

샘플 애플리케이션은 방문자 IP를 로깅, 검색, 표시합니다.

애플리케이션은 먼저 Datastore 모드 클라이언트를 인스턴스화합니다.

$datastore = new DatastoreClient([
    'projectId' => $projectId
]);

각 방문은 방문자의 IP 주소와 타임스탬프에 해당하는 필드가 있는 항목이며 insert 명령어를 사용하여 Datastore 모드에 저장됩니다.

// Create an entity to insert into datastore.
$key = $datastore->key('visit');
$entity = $datastore->entity($key, [
    'user_ip' => $user_ip,
    'timestamp' => new DateTime(),
]);
$datastore->insert($entity);

query 명령어를 사용하여 최근의 방문 10개가 내림차순으로 검색됩니다.

// Query recent visits.
$query = $datastore->query()
    ->kind('visit')
    ->order('timestamp', 'DESCENDING')
    ->limit(10);
$results = $datastore->runQuery($query);
$visits = [];
foreach ($results as $entity) {
    $visits[] = sprintf('Time: %s Addr: %s',
        $entity['timestamp']->format('Y-m-d H:i:s'),
        $entity['user_ip']);
}

index.yaml 파일 사용

샘플 앱에서는 간단한 쿼리를 수행합니다. 보다 정교한 Datastore 모드 쿼리를 실행하려면 색인이 한 개 이상 필요하며 앱과 함께 업로드하는 index.yaml 파일에서 색인을 지정해야 합니다. 이 파일은 수동으로 만들거나 로컬에서 앱을 테스트하는 동안 자동으로 생성될 수 있습니다.

로컬 테스트

로컬에서 애플리케이션을 개발하고 테스트해야 하는 경우 Datastore 모드 에뮬레이터를 사용할 수 있습니다.

추가 정보

최적화와 개념을 비롯하여 Datastore 모드에 대한 자세한 내용은 Datastore 모드 문서의 Firestore를 참조하세요.