Docs Menu
Docs Home
/ /
MongoDB Atlas Kubernetes Operator
/

AtlasDataFederation 사용자 지정 리소스

이 페이지의 내용

  • 예시
  • 매개변수

참고

Atlas Kubernetes Operator는 정부용 Atlas에 대해 AtlasDataFederation 사용자 지정 리소스를 지원하지 않습니다.

AtlasDataFederation 사용자 지정 리소스는 Atlas에서 federated database instance 를 구성합니다. AtlasDataFederation 사용자 지정 리소스를 만들면 Atlas Kubernetes Operator가 Atlas에서 연합 데이터베이스 인스턴스를 만들거나 업데이트하려고 시도합니다. 연합 데이터베이스 인스턴스를 사용하여 연합 쿼리를 실행할 수 있습니다.

중요

Custom Resource(사용자 정의 리소스)는 더 이상 기본적으로 객체를 삭제하지 않음

Atlas Kubernetes Operator는 사용자 지정 리소스 구성 파일을 사용하여 Atlas 구성을 관리합니다. 다만 Atlas Kubernetes Operator 2.0부터는 Kubernetes에서 삭제한 사용자 지정 리소스가 더 이상 Atlas에서 삭제되지 않습니다. 대신 Atlas Kubernetes Operator에서는 이러한 리소스의 관리가 중단될 뿐입니다. 그 예로 Kubernetes에서 AtlasProject 사용자 지정 리소스를 삭제하는 경우, Atlas Kubernetes Operator는 Atlas에서 해당 프로젝트를 더 이상 자동으로 삭제하지 않음으로써 우발적이거나 예기치 못한 삭제를 방지할 수 있습니다. Atlas Kubernetes Operator 2.0 이전에 사용된 기본값으로 이 동작을 되돌리는 방법을 포함하여 자세한 내용은 새로운 기본값: Atlas Kubernetes Operator 2.0의 삭제 방지를 참조하세요.

Atlas Kubernetes Operator는 Atlas Clusters API Resource (클러스터 API 리소스) 및 Advanced Clusters API Resource (고급 클러스터 API 리소스)를 사용하여 새 연합 데이터베이스 인스턴스를 생성하거나 기존 연합 데이터베이스 인스턴스를 업데이트합니다. spec.serverlessSpec 아래의 필드에 값을 지정하는 경우, Atlas Kubernetes Operator는 Atlas Serverless Instance API Resource (서버리스 인스턴스 API 리소스)를 사용하여 연합 데이터베이스 인스턴스에 대한 비공개 엔드포인트를 생성하거나 구성합니다.

Kubernetes 클러스터에서 AtlasDataFederation 리소스를 제거하면 Atlas Kubernetes Operator가 Atlas에서 연합 데이터베이스 인스턴스를 제거합니다.

다음 예제에서는 비공개 엔드포인트가 구성된 AtlasDataFederation 사용자 지정 리소스 사양을 보여줍니다.

apiVersion: atlas.mongodb.com/v1
kind: AtlasDataFederation
metadata:
name: my-federated-deployment
spec:
projectRef:
name: my-project
namespace: default
cloudProviderConfig:
aws:
roleId: 12345678
testS3Bucket: my-bucket
dataProcessRegion:
cloudProvider: AWS
region: OREGON_USA
name: my-fdi
storage:
databases:
- collections:
- dataSources:
- allowInsecure: false
collection: my-collection
collectionRegex:
database: my-database
databaseRegex:
defaultFormat: ".avro"
path: /
provenanceFieldName: string
storeName: my-data-store
urls:
- string:
name: my-collection-mdb
maxWildcardCollections: 100
name: my-database-mdb
views:
- name: my-view
pipeline:
source: my-source-collection
stores:
- name: my-store
provider: S3
additionalStorageClasses:
- STANDARD
bucket: my-bucket
delimiter: /
includeTags: false
prefix: data-
public: false
region: US_WEST_1
privateEndpoints:
- endpointId: vpce-3bf78b0ddee411ba1
provider: AWS
type: DATA_LAKE
- endpointId: vpce-3bf78b0ddee411ba2
provider: AWS
type: DATA_LAKE

이 섹션에서는 사용 가능한 주요 AtlasDataFederation 사용자 지정 리소스 매개변수 몇 가지에 대해 설명합니다. 사용 가능한 매개변수의 전체 목록은 Atlas Data Federation API를 참조하세요.

사양을 사용자 지정하려면 이러한 설명, 사용 가능한 예제, API 문서를 참조하세요.

metadata.name

유형: 문자열

필수 사항

Atlas Kubernetes Operator가 이 연합 데이터베이스 인스턴스를 프로젝트에 추가하는 데 사용하는 AtlasDataFederation 사용자 지정 리소스 를 식별하는 레이블입니다.

spec.cloudProviderConfig

유형: 객체

필수 사항

연합 데이터베이스 인스턴스에 대한 클라우드 제공자 구성이 포함된 목록입니다.

spec.cloudProviderConfig.aws

유형: 객체

필수 사항

연합 데이터베이스 인스턴스를 호스팅하는 cloud 서비스 제공자의 이름입니다.

spec.cloudProviderConfig.aws.roleId

유형: 문자열

필수 사항

연합 데이터베이스 인스턴스가 데이터 저장소에 액세스하는 데 사용할 수 있는 역할의 고유 식별자입니다.

spec.cloudProviderConfig.aws.testS3Bucket

유형: 문자열

필수 사항

제공된 역할 ID에 액세스 권한이 부여된 S3 데이터 버킷의 이름입니다.

spec.dataProcessRegion

유형: 객체

필수 사항

연합 데이터베이스 인스턴스가 클라이언트 연결을 라우팅하는 클라우드 제공자 리전에 대한 정보입니다. Atlas Kubernetes Operator는 Amazon Web Services 만 지원합니다.

spec.dataProcessRegion.cloudProvider

유형: 문자열

필수 사항

연합 데이터베이스 인스턴스의 데이터 저장소를 호스팅하는 클라우드 서비스 제공자의 이름입니다. Atlas Kubernetes Operator에서는 다음 값을 허용합니다.

  • AWS

  • TENANT

  • SERVERLESS

spec.dataProcessRegion.region

유형: 문자열

필수 사항

연합 데이터베이스 인스턴스 데이터 저장소의 지리적 위치를 나타내는 레이블입니다. Atlas Kubernetes Operator에서는 다음 값을 허용합니다.

  • SYDNEY_AUS

  • MUMBAI_IND

  • FRANKFURT_DEU

  • DUBLIN_IRL

  • LONDON_GBR

  • VIRGINIA_USA

  • OREGON_USA

  • SAOPAULO_BRA

  • SINGAPORE_SGP

spec.name

유형: 문자열

옵션

Atlas에서 연합 데이터베이스 인스턴스를 식별하는 레이블입니다.

spec.storage

유형: 객체

옵션

각 데이터 저장소 및 Atlas 데이터베이스에 대한 매핑에 대한 구성 정보입니다.

spec.storage.databases

유형: 배열

옵션

이 연합 데이터베이스 인스턴스에 대한 쿼리 가능 데이터베이스 및 collection이 포함된 목록입니다.

spec.storage.databases.collections

유형: 배열

옵션

stores 데이터 저장소에 매핑되는 컬렉션 및 데이터 소스의 목록입니다.

spec.storage.databases.collections.dataSources

유형: 배열

옵션

이 연합 데이터베이스 인스턴스의 컬렉션에 매핑되는 데이터 저장소가 포함된 목록입니다.

spec.storage.databases.collections.dataSources.allowInsecure

유형: 부울

옵션

지정된 URL의 체계의 유효성을 검사하는 플래그입니다. true 인 경우, Atlas Kubernetes Operator는 안전하지 않은 HTTP 체계를 허용하고, 서버의 인증서 체인과 호스트 이름을 확인하지 않으며, 서버에서 제공하는 호스트 이름을 가진 인증서를 수락합니다. false 인 경우, Atlas Kubernetes Operator는 HTTPS 체계만 보안을 허용합니다.

spec.storage.databases.collections.dataSources.collection

유형: 문자열

옵션

데이터베이스에서 컬렉션을 식별하는 사람이 읽을 수 있는 레이블입니다. 와일드카드(*) collection을 만들려면 이 매개변수를 생략해야 합니다.

spec.storage.databases.collections.dataSources.collectionRegex

유형: 문자열

옵션

와일드카드(*) collection을 만드는 데 사용할 정규식 패턴입니다.

spec.storage.databases.collections.dataSources.database

유형: 문자열

옵션

클러스터의 컬렉션을 포함하는 데이터베이스를 식별하는 사람이 읽을 수 있는 레이블입니다. 동적으로 생성된 데이터베이스에 대한 와일드카드(*) collection을 생성하려면 이 매개변수를 생략해야 합니다.

spec.storage.databases.collections.dataSources.databaseRegex

유형: 문자열

옵션

와일드카드(*) 데이터베이스를 만드는 데 사용할 정규식 패턴입니다.

spec.storage.databases.collections.dataSources.defaultFormat

유형: 문자열

옵션

storeName 을(를) 검색하는 동안 파일 확장자가 없는 파일을 발견하는 경우 Atlas Kubernetes Operator가 사용하는 파일 형식입니다. Atlas Kubernetes Operator에서는 다음 값을 허용합니다.

  • .avro

  • .avro.bz2

  • .avro.gz

  • .bson

  • .bson.bz2

  • .bson.gz

  • .bsonx

  • .csv

  • .csv.bz2

  • .csv.gz

  • .json

  • .json.bz2

  • .json.gz

  • .orc

  • .parquet

  • .tsv

  • .tsv.bz2

  • .tsv.gz

spec.storage.databases.collections.dataSources.path

유형: 문자열

옵션

Atlas Kubernetes Operator가 파일을 collection에 매핑하기 전에 storeName 에서 파일을 검색하는 방법을 제어하는 파일 경로입니다. 접두사 경로의 모든 파일과 폴더를 캡처하려면 / 을 지정합니다.

spec.storage.databases.collections.dataSources.provenanceFieldName

유형: 문자열

옵션

결과에 있는 문서의 출처가 포함된 필드를 식별하는 사람이 읽을 수 있는 레이블입니다. Atlas Kubernetes Operator는 지원되는 각 제공자에 대해 결과에서 서로 다른 필드를 반환합니다.

spec.storage.databases.collections.dataSources.storeName

유형: 문자열

옵션

Atlas Kubernetes Operator가 컬렉션에 매핑하는 데이터 저장소를 식별하는 인간 판독 가능 레이블.

spec.storage.databases.collections.dataSources.urls

유형: 배열

옵션

공개적으로 액세스할 수 있는 데이터 파일의 URL입니다. 인증이 필요한 URL은 지정할 수 없습니다. Atlas Data Federation은 각 URL에 대한 파티션을 생성합니다. 비어 있거나 생략된 경우 Atlas Data Federation은 dataSources.storeName 매개변수에 지정된 스토어의 URL을 사용합니다.

spec.storage.databases.collections.name

유형: 문자열

옵션

Atlas Kubernetes Operator가 데이터 저장소의 데이터를 매핑하는 collection을 식별하는 인간 판독 가능 레이블.

spec.storage.databases.maxWildcardCollections

유형: int32

옵션

데이터베이스에 있는 와일드카드 collection의 최대 개수입니다. 이는 S3 데이터 소스에만 적용됩니다. 기본값은 100 입니다.

spec.storage.databases.name

유형: 문자열

옵션

연합 데이터베이스 인스턴스가 데이터를 매핑하는 데이터베이스를 식별하는 인간 판독 가능 레이블.

spec.storage.databases.views

유형: 배열

옵션

collection에 적용되는 집계 파이프라인의 목록입니다. 이는 S3 데이터 소스에만 적용됩니다.

spec.storage.databases.views.name

유형: 문자열

옵션

collection의 집계 파이프라인에 해당하는 뷰를 식별하는 인간 판독 가능 레이블.

spec.storage.databases.views.pipeline

유형: 문자열

옵션

소스 collection에 적용할 집계 파이프라인 단계입니다.

spec.storage.databases.views.source

유형: 문자열

옵션

뷰의 소스 collection을 식별하는 사람이 읽을 수 있는 레이블입니다.

spec.storage.stores

유형: 배열

옵션

연합 데이터베이스 인스턴스의 데이터 저장소가 포함된 목록입니다.

spec.storage.stores.name

유형: 문자열

옵션

데이터 저장소를 식별하는 사람이 읽을 수 있는 레이블입니다. spec.storage.databases.collections.dataSources.storeName 필드는 매핑 구성의 일부로 이 값을 참조합니다.

spec.storage.stores.provider

유형: 문자열

조건부

스토어의 제공자입니다. Atlas Kubernetes Operator는 S3 만 지원합니다. 데이터 저장소를 사용하려면 이 필드를 지정해야 합니다.

spec.storage.stores.additionalStorageClasses

유형: 배열

옵션

AWS S3 스토리지 클래스의 컬렉션입니다. Atlas Data Federation은 쿼리 결과에 이러한 저장소 클래스의 파일을 포함합니다. Atlas Kubernetes Operator에서는 다음 값을 허용합니다.

  • STANDARD

  • INTELLIGENT_TIERING

  • STANDARD_IA

spec.storage.stores.bucket

유형: 문자열

옵션

AWS S3 버킷을 식별하는 사람이 읽을 수 있는 레이블입니다. 이 레이블은 연합 데이터베이스 인스턴스가 구성된 Amazon Web Services IAM 자격 증명을 사용하여 액세스할 수 있는 S3 버킷의 이름과 정확히 일치해야 합니다.

spec.storage.stores.delimiter

유형: 문자열

옵션

데이터 저장소에서 spec.storage.databases.collections.dataSources.path 세그먼트를 구분하는 구분 기호입니다. Atlas Kubernetes Operator는 구분 기호를 사용하여 계층적 디렉토리 구조의 S3 버킷을 효율적으로 탐색합니다. S3 객체 키에서 지원하는 모든 문자를 구분 기호로 지정할 수 있습니다. 예를 들어 밑줄(_) 또는 더하기 기호(+)를 지정하거나 이중 밑줄(__)과 같은 여러 문자를 구분 기호로 지정할 수 있습니다. 생략하면 기본값은 / 입니다.

spec.storage.stores.includeTags

유형: 부울

옵션

지정된 경로의 파일에 S3 태그를 추가 파티션 속성으로 사용할지 여부를 나타내는 플래그입니다. true로 설정하면 Atlas Kubernetes Operator가 S3 태그를 추가 파티션 속성으로 추가하고, 각 태그를 각 문서에 연결하는 새로운 최상위 BSON 요소를 추가합니다. 생략하면 기본값은 false 입니다.

spec.storage.stores.prefix

유형: 문자열

옵션

S3 버킷에서 파일을 검색할 때 Atlas Kubernetes Operator가 적용하는 접두사입니다. 데이터 저장소는 spec.storage.databases.collections.dataSources.path 에 접두사 값을 추가하여 수집할 파일의 전체 경로를 생성합니다. 생략하면 Atlas Kubernetes Operator가 S3 버킷의 루트에서 모든 파일을 검색합니다.

spec.storage.stores.public

유형: 부울

옵션

버킷의 공개 여부를 나타내는 플래그입니다. true 으로 설정된 경우 Atlas Kubernetes Operator는 구성된 Amazon Web Services IAM 역할을 사용하여 S3 버킷에 액세스하지 않습니다. false 로 설정된 경우 구성된 Amazon Web Services IAM 역할에 S3 버킷에 액세스할 수 있는 권한이 포함되어야 합니다.

spec.storage.stores.region

유형: 문자열

옵션

S3 버킷의 물리적 위치를 나타내는 AWS 리전입니다.

spec.privateEndpoints

유형: 배열

옵션

연합 데이터베이스 인스턴스에 대한 비공개 엔드포인트 구성이 포함된 목록입니다.

spec.privateEndpoints.endpointId

유형: 문자열

필수 사항

AWS의 비공개 엔드포인트를 식별하는 vpce- 로 시작하는 고유한 22자 영숫자 문자열

spec.privateEndpoints.provider

유형: 문자열

옵션

cloud 서비스 제공자를 식별하는 사람이 읽을 수 있는 레이블입니다. Atlas Data Federation은 AWS 만 지원합니다.

spec.privateEndpoints.type

유형: 문자열

옵션

이 비공개 엔드포인트와 연결된 리소스 유형을 식별하는 사람이 읽을 수 있는 레이블입니다. Atlas Data Federation은 DATA_LAKE 만 지원합니다.

spec.projectRef.name

유형: 문자열

필수 사항

연합 데이터베이스 인스턴스가 속한 프로젝트의 이름입니다. 기존 AtlasProject 사용자 지정 리소스를 지정해야 합니다.

spec.projectRef.namespace

유형: 문자열

필수 사항

spec.projectRef.name 에 지정된 AtlasProject 사용자 지정 리소스 가 존재하는 네임스페이스입니다.

← AtlasTeam 사용자 지정 리소스

이 페이지의 내용