프로그래매틱 분석 도구

이 문서에서는 BigQuery에서 관리되는 데이터를 분석하기 위한 코드를 작성하고 실행하는 여러 방법을 설명합니다.

SQL이 강력한 쿼리 언어이긴 해도 특정 유형의 데이터를 분석하기 위해서는 Python, 자바, R과 같은 프로그래밍 언어에서 제공되는 구문 및 여러 내장된 통계 함수를 사용하는 것이 더 직관적이고 쉬울 수 있습니다.

마찬가지로 스프레드시트가 널리 사용되더라도, 때로는 복잡한 데이터 분석 및 탐색을 수행할 때 메모장과 같은 더 탄력적인 가변형 환경을 이용는 것이 더 유연할 수 있습니다.

Jupyter 노트북

Jupyter는 라이브 코드, 텍스트 설명, 시각화를 포함하는 노트북을 게시하기 위한 오픈소스 웹 기반 애플리케이션입니다. 이 플랫폼은 데이터과학자, 머신러닝 전문가, 학생들이 데이터 정리 및 변환, 수치 시뮬레이션, 통계적 모델링, 데이터 시각화, 머신러닝 등을 위해 일반적으로 사용하는 도구입니다.

Jupyter 노트북은 BigQuery용 IPython Magics를 사용하여 BigQuery와 직접 상호작용할 수 있는 강력한 대화형 셸인 IPython 커널을 기반으로 작성되었습니다. 또는 무엇이든 사용 가능한 BigQuery 클라이언트 라이브러리를 설치하여 Jupyter 노트북 인스턴스에서 BigQuery에 액세스할 수 있습니다. GeoJSON 확장 프로그램을 통해 Jupyter 메모장으로 BigQuery GIS 데이터를 시각화할 수 있습니다. BigQuery 통합에 대한 자세한 내용은 Jupyter 노트북에서 BigQuery 데이터 시각화 튜토리얼을 참조하세요.

BigQuery GIS 데이터의 시각화를 보여주는 Jupyter 메모장 차트

JupyterLab은 Jupyter 노트북, 텍스트 편집기, 터미널, 커스텀 구성요소와 같이 문서 및 활동을 관리하기 위한 웹 기반 사용자 인터페이스입니다. JupyterLab에서는 탭과 분할자를 사용하여 작업 영역에 여러 문서 및 활동을 나란히 배열할 수 있습니다.

JupyterLab: 탭 및 분할자를 사용하여 작업 영역에 여러 문서 및 활동을 나란히 배열

다음 제품 중 하나를 사용하여 Jupyter 노트북과 JupyterLab 환경을 Google Cloud에 배포할 수 있습니다.

Apache Zeppelin

Apache Zeppelin은 데이터 애널리틱스를 위한 웹 기반 노트북을 제공하는 오픈소스 프로젝트입니다. Zeppelin 선택적 구성요소를 설치하여 Dataproc에 Apache Zeppelin 인스턴스를 배포할 수 있습니다. 기본적으로 노트북은 사용자가 지정하거나 클러스터를 만들 때 자동 생성되는 Cloud Dataproc 스테이징 버킷의 Cloud Storage에 저장됩니다. 클러스터를 만들 때 속성 zeppelin:zeppelin.notebook.gcs.dir을 추가하여 노트북 위치를 변경할 수 있습니다. Apache Zeppelin을 설치하고 구성하는 방법에 대한 자세한 내용은 Zeppelin 구성요소 가이드를 참조하세요. 예시를 보려면 Apache Zeppelin을 위한 BigQuery 인터프리터를 사용하여 BigQuery 데이터 세트 분석을 참조하세요.

Zeppelin에 표시된 테이블 데이터의 SQL 분석

Apache Hadoop, Apache Spark, Apache Hive

데이터 분석 파이프라인 마이그레이션 중에는 데이터 웨어하우스에서 직접 데이터를 처리해야 하는 일부 레거시 Apache Hadoop, Apache Spark 또는 Apache Hive 작업을 마이그레이션해야 할 수 있습니다. 예를 들어 머신러닝 워크로드를 위한 기능을 추출해야 할 수 있습니다.

Dataproc을 사용하면 효율적이고 경제적인 방식으로 완전 관리형 Hadoop 및 Spark 클러스터를 배포할 수 있습니다. Dataproc은 오픈소스 BigQuery 커넥터와 통합됩니다. 이러한 커넥터는 BigQuery Storage API를 사용하며, gRPC를 통해 BigQuery에서 직접 데이터를 병렬로 스트리밍합니다.

기존 Hadoop 및 Spark 워크로드를 Dataproc에 마이그레이션할 때는 워크로드의 종속 항목이 지원되는 Dataproc 버전에 포함되는지 확인할 수 있습니다. 커스텀 소프트웨어를 설치해야 할 경우 자체 Dataproc 이미지를 만들거나 자체 초기화 작업을 작성하거나 커스텀 Python 패키지 요구사항을 지정할 수 있습니다.

시작하려면 Dataproc 빠른 시작 가이드BigQuery 커넥터 코드 샘플을 참조하세요.

Apache Beam

Apache BeamBigQuery용 커넥터를 포함하여 소스 및 싱크 커넥터의 생태계는 물론 다양한 윈도잉과 세션 분석 기본 도구를 제공하는 오픈소스 프레임워크입니다. Apache Beam은 스트리밍(실시간) 모드와 일괄(기록) 모드에서 신뢰성과 표현 능력을 동일하게 지원하면서 데이터를 변환하고 강화할 수 있게 해줍니다.

Dataflow는 Apache Beam 작업을 대규모로 실행하기 위한 완전 관리형 서비스입니다. Dataflow 서버리스 접근 방식은 성능, 확장, 가용성, 보안 및 규정 준수가 자동으로 처리되어 운영 오버헤드가 없기 때문에 서버 클러스터 관리 대신 프로그래밍에 집중할 수 있습니다.

확장된 복합 변환(MakeMapView)이 포함된 실행 그래프 부차 입력을 만드는 하위 변환(CreateDataflowView)이 선택되고 부차 입력 측정항목이 단계 탭에 표시됩니다.

Dataflow 작업은 명령줄 인터페이스, 자바 SDK, Python SDK를 통해 여러 방법으로 제출할 수 있습니다.

다른 프레임워크에서 Apache Beam 및 Dataflow로 데이터 쿼리 및 파이프라인을 마이그레이션하려면 Apache Beam 프로그래밍 모델 및 공식 Dataflow 문서를 참조하세요.

RStudio

데이터과학자는 종종 R 프로그래밍 언어를 사용하여 데이터 분석 도구와 통계 앱을 빌드합니다. RStudio는 R을 위한 무료 오픈소스 도구와 팀의 업무 확장 및 공유를 위한 기업용 전문 제품들을 개발하고 있습니다. RStudio Server Pro와 같은 RStudio 제품들은 R을 사용한 데이터 분석을 단순화하고 게시 및 공유를 위한 강력한 도구들을 제공합니다.

RStudio Server Pro는 상업적으로 라이센스가 필요한 주문형 통합 개발 환경(IDE)입니다. 이 제품은 인기 있는 RStudio 오픈소스 IDE에 있는 기능과 여러 R 버전 및 세션을 관리하는 기능과 향상된 보안, 턴키 편의성 등을 제공합니다.

Cloud Marketplace에서 Google Cloud용 RStudio Server Pro 구성요소를 배포할 수 있습니다. 이 버전은 RStudio Server Pro와 동일하지만 여러 R 버전의 사전 설치 및 공통 시스템 라이브러리가 포함되어 데이터과학자에게 더 편리합니다. 또한 R용 BigQuery 패키지인 bigrquery가 포함되어 있습니다. 이 패키지는 로우레벨 SQL 또는 하이레벨 dplyr 동사를 사용하여 BigQuery와 상호작용할 수 있게 해주는 DBIdplyr 백엔드를 제공합니다. 이 패키지를 사용하면 BigQuery 테이블을 쿼리하고 프로젝트, 데이터 세트, 테이블, 작업에 대한 메타데이터를 검색할 수 있기 때문에 BigQuery에 저장된 데이터의 작업이 간소화됩니다. 자세한 내용은 Google Cloud용 RStudio Server Pro 시작하기 공식 가이드 및 Google Cloud를를 위한 RStudio Server Pro FAQ를 참조하세요.

Dataproc 클러스터에 RStudio Server의 오픈소스 버전을 설치할 수도 있습니다. Dataproc에서 RStudio를 실행하면 Dataproc 자동 확장을 활용할 수 있다는 장점이 있습니다. 자동 확장을 사용할 수 있으면 SparkR 논리를 개발할 때 클러스터 크기를 최소한으로 지정할 수 있습니다. 대규모 처리를 위한 작업을 제출한 후에도 다른 작업을 수행하거나 서버를 수정할 필요가 없습니다. SparkR 작업을 RStudio에 제출하면 설정된 간격 내에 Dataproc 클러스터가 작업 요구에 맞게 확장됩니다. Dataproc과의 RStudio 통합에 대한 세부정보는 공식 공지를 참조하세요.

기타 리소스

BigQuery는 자바, Go, Python, 자바스크립트, PHP, Ruby와 같은 여러 프로그래밍 언어로 다양한 클라이언트 라이브러리를 제공합니다. Pandas와 같은 일부 데이터 분석 프레임워크는 BigQuery와 직접 상호작용하는 플러그인을 제공합니다. 일부 실제 예시를 보려면 Jupyter 노트북에서 BigQuery 데이터 시각화 튜토리얼을 참조하세요.

마지막으로 셸 환경에서 프로그램을 작성하는 것이 더 좋으면 bq 명령줄 도구를 사용할 수 있습니다.