> 백엔드 개발 > Golang > Go에서 Google Bigtable 사용: 전체 가이드

Go에서 Google Bigtable 사용: 전체 가이드

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2023-06-18 17:15:11
원래의
1656명이 탐색했습니다.

클라우드 컴퓨팅과 빅데이터 기술의 발전으로 Google Bigtable은 많은 기업이 데이터를 저장하는 데 선호하는 솔루션이 되었습니다. 분산형 NoSQL 데이터베이스 서비스인 Google Bigtable은 확장성, 고가용성, 고성능 및 기타 기능을 제공하며 점점 더 많은 기업에서 선호하고 있습니다. 이 글에서는 Google Bigtable을 Go 언어로 사용하는 방법을 소개합니다.

1. Golang SDK 및 Google Cloud SDK 설치

Google Bigtable을 사용하기 전에 Golang SDK 및 Google Cloud SDK를 설치해야 합니다. Golang 공식 웹사이트에서 최신 버전의 Golang SDK를 다운로드하여 설치할 수 있습니다. 동시에 Google Cloud에서 제공하는 다양한 서비스를 사용하려면 Google Cloud SDK도 설치해야 합니다.

2. Google Cloud 계정 생성 및 Bigtable 서비스 시작

Google Bigtable을 사용하기 전에 Google Cloud 계정을 생성하고 Bigtable 서비스를 시작해야 합니다. 필요에 따라 다양한 서비스 패키지를 선택할 수 있습니다. 구체적인 패키지 정보는 Google Cloud 공식 웹사이트에서 확인할 수 있습니다.

3. 새 테이블 만들기

Google Bigtable은 테이블을 사용하여 데이터를 관리하므로 먼저 새 테이블을 만들어야 합니다. Google Cloud에서 제공하는 Bigtable Admin API를 사용하여 새 테이블을 만들거나 명령줄 도구 gcloud를 사용하여 새 테이블을 만들 수 있습니다. 여기서는 gcloud를 사용하여 새 테이블을 만듭니다. 구체적인 명령은 다음과 같습니다.

gcloud bigtable instances create [INSTANCE_ID] 
     --cluster=[CLUSTER_ID] 
     --cluster-zone=[CLUSTER_ZONE] 
     --description=[DESCRIPTION] 
     --instance-type=[TYPE]
로그인 후 복사

여기서 [INSTANCE_ID]는 새 인스턴스의 고유 식별자이고, [CLUSTER_ID]는 인스턴스의 단일 노드이고, [CLUSTER_ZONE]은 노드의 지리적 위치이며, [DESCRIPTION]은 인스턴스에 대한 간단한 설명입니다. [TYPE]은 인스턴스 유형입니다.

4. 새 열 패밀리 만들기

Bigtable에서 열 패밀리(Column Family)는 유사한 속성을 가진 데이터를 저장하는 데 사용되는 열의 논리적 그룹입니다. 명령줄 도구 cbt를 사용하여 새 열 패밀리를 생성할 수 있습니다. 구체적인 명령은 다음과 같습니다.

cbt createfamily [TABLE_ID] [FAMILY_ID]
로그인 후 복사

여기서 [TABLE_ID]는 테이블의 고유 식별자이고 [FAMILY_ID]는 새 열 계열의 고유 식별자입니다.

5. 데이터 삽입

Bigtable을 사용하여 데이터를 저장할 때는 행 키와 열 이름을 사용하여 데이터를 식별해야 합니다. 명령줄 도구 cbt를 사용하여 데이터를 삽입할 수 있습니다.

cbt set [TABLE_ID] 
     [ROW_KEY] 
     [COLUMN_FAMILY]:[COLUMN_QUALIFIER]=[VALUE]
로그인 후 복사

여기서 [TABLE_ID]는 테이블의 고유 식별자, [ROW_KEY]는 행 키, [COLUMN_FAMILY]는 열 패밀리, [COLUMN_QUALIFIER]는 열 이름, [VALUE]는 값입니다.

6. 데이터 쿼리

명령줄 도구인 cbt를 사용하여 데이터를 쿼리할 수 있습니다.

cbt read [TABLE_ID] 
     [ROW_KEY] 
     [COLUMN_FAMILY]:[COLUMN_QUALIFIER]
로그인 후 복사

여기서 [TABLE_ID]는 테이블의 고유 식별자이고, [ROW_KEY]는 행 키, [COLUMN_FAMILY]는 열 패밀리, [COLUMN_QUALIFIER]는 열 이름입니다.

7. Go 언어로 Google Bigtable 사용하기

Google Bigtable을 Go 언어로 사용하려면 Google Cloud에서 제공하는 Bigtable API를 사용해야 합니다. 다음 명령을 사용하여 Bigtable API를 설치할 수 있습니다.

go get -u cloud.google.com/go/bigtable
로그인 후 복사

설치가 완료된 후 Bigtable API를 사용하여 데이터를 읽고 쓸 수 있습니다. 다음은 데이터를 삽입하고 데이터를 쿼리하는 샘플 프로그램입니다.

package main

import (
    "context"
    "log"

    "cloud.google.com/go/bigtable"
)

func main() {
    ctx := context.Background()

    adminClient, err := bigtable.NewAdminClient(ctx, "project-id", "instance-id")
    if err != nil {
        log.Fatalf("Failed to create admin client: %v", err)
    }
    defer adminClient.Close()

    err = adminClient.CreateTable(ctx, "table-id")
    if err != nil {
        log.Fatalf("Failed to create table: %v", err)
    }

    err = adminClient.CreateColumnFamily(ctx, "table-id", "column-family")
    if err != nil {
        log.Fatalf("Failed to create column family: %v", err)
    }

    client, err := bigtable.NewClient(ctx, "project-id", "instance-id")
    if err != nil {
        log.Fatalf("Failed to create client: %v", err)
    }
    defer client.Close()

    table := client.Open("table-id")

    mut := bigtable.NewMutation()
    mut.Set("column-family", "column1", bigtable.Now(), []byte("value1"))
    mut.Set("column-family", "column2", bigtable.Now(), []byte("value2"))

    err = table.Apply(ctx, "row-key", mut)
    if err != nil {
        log.Fatalf("Failed to apply mutation: %v", err)
    }

    row, err := table.ReadRow(ctx, "row-key")
    if err != nil {
        log.Fatalf("Failed to read row: %v", err)
    }

    log.Printf("Row: %v
", row)
}
로그인 후 복사

위 샘플 코드에서는 먼저 Google Cloud에 연결하고 새 테이블과 새 열 계열을 만든 다음 데이터를 삽입하고 데이터를 쿼리합니다.

Google Bigtable이 모든 시나리오에 적합한 것은 아니며, 실제 상황에 따라 사용 여부를 선택해야 한다는 점에 유의하시기 바랍니다. 또한 데이터 보안과 개인정보 보호에도 주의를 기울여야 합니다.

위 내용은 Go에서 Google Bigtable 사용: 전체 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿