문서 메뉴

문서 홈애플리케이션 개발MongoDB 매뉴얼

자동 필드 레벨 암호화를 통한 읽기/쓰기 지원

이 페이지의 내용

  • 지원되는 읽기 및 쓰기 명령
  • 지원되는 쿼리 연산자
  • 지원되는 업데이트 연산자
  • 지원되지 않는 삽입 작업
  • 지원되는 집계 단계
  • 지원되지 않는 필드 유형

참고

엔터프라이즈 기능

필드 레벨 암호화의 자동 기능은 MongoDB Enterprise 4.2 이상 및 MongoDB Atlas 4.2 이상 cluster에서만 사용할 수 있습니다.

버전 4.2에 추가되었습니다.

이 문서에서는 자동 클라이언트 사이드 필드 수준 암호화를 위해 구성된 4.2+ 호환 드라이버에서 지원하는 특정 명령, 쿼리 연산자, 업데이트 연산자, 애그리게이션 단계 및 애그리게이션 표현식을 설명합니다.

MongoDB는 클라이언트 사이드 필드 수준의 암호화된 필드를 BinData 블롭으로 저장합니다. Read and write operations issued against the encrypted BinData value may have unexpected or incorrect behavior as compared to issuing that same operation against the decrypted value. 특정 작업은 BinData 값에 대해 실행하면 오류가 반환되는 엄격한 BSON 유형 지원이 있습니다.

  • 자동 클라이언트 사이드 필드 수준 암호화를 사용하는 공식 4.2+ 호환 드라이버는 BinData 값을 지원하지 않거나 BinData 값에 대해 실행될 때 비정상적인 동작을 보이는 연산자 또는 표현식에 대해 읽기/쓰기 작업을 구문 분석합니다.

  • 명시적(수동) 클라이언트 사이드 필드 수준 암호화 사용하는 애플리케이션은 이 페이지를 암호화된 필드에 읽기/쓰기 작업을 실행하기 위한 지침으로 사용할 수 있습니다.

공식 MongoDB 4.2+ 호환 드라이버는 다음 명령을 사용하여 자동 클라이언트 사이드 필드 레벨 암호화 를 지원합니다.

지원되는 명령에 대해 명령이 지원되지 않는 연산자, 애그리게이션 단계 또는 애그리게이션 표현식을 사용하는 경우 4.2+ 호환 드라이버에서 오류를 반환합니다.

  • 지원되는 쿼리 연산자

  • 지원되는 업데이트 연산자

  • 지원되는 애그리게이션 표현식

  • 지원되는 집계 단계

다음 명령은 자동 암호화가 필요하지 않습니다. 자동 클라이언트 사이드 필드 레벨 암호화를 위해 구성된 공식 MongoDB 4.2+ 호환 드라이버는 이러한 명령을 mongod 에 직접 전달합니다.

클라이언트 사이드 필드 수준 자동 암호화를 위해 구성된 4.2 이상 호환 드라이버를 통해 다른 명령 을 실행하면 오류가 반환됩니다.

[1] 클라이언트 사이드 필드 수준 자동 암호화는 getMore 명령을 암호화하지 않지만 명령에 대한 응답에는 암호화된 필드 값이 포함될 수 있습니다. 올바른 클라이언트 사이드 필드 수준 암호화 옵션으로 구성된 애플리케이션은 해당 값을 자동으로 해독 합니다. 올바른 암호화 옵션이 없는 애플리케이션은 암호화된 값만 볼 수 있습니다.

자동 클라이언트 사이드 필드 수준 암호화를 위해 구성된 공식 4.2+ 호환 드라이버는 결정론적 으로 암호화된 필드에 대해 실행될 때 다음 쿼리 연산자를 허용합니다.

암호화된 필드를 null 또는 정규 표현식과 비교하는 쿼리는 지원되는 쿼리 연산자를 사용 하더라도 항상 오류를 발생시킵니다. 무작위로 암호화된 필드에 대해 이러한 연산자를 실행하는 쿼리는 오류를 발생시킵니다.

$exists 연산자는 결정론적으로 암호화된 필드와 무작위로 암호화된 필드 모두에 대해 실행될 때 정상적인 동작을 합니다.

암호화된 필드에 대해 다른 쿼리 연산자를 지정하는 쿼리는 오류를 반환합니다.

다음 쿼리 연산자는 암호화된 필드에 대해 실행되지 않은 경우에도 오류를 발생시킵니다.

자동 클라이언트 사이드 필드 수준 암호화를 위해 구성된 공식 4.2+ 호환 드라이버는 결정론적 으로 암호화된 필드에 대해 실행될 때 다음과 같은 업데이트 연산자를 허용합니다.

암호화된 필드에 $rename 연산자를 사용하는 업데이트 작업의 경우 자동 JSON schema가 소스 및 대상 필드 이름에 대해 동일한 암호화 메타데이터를 지정하는지 확인합니다.

암호화된 필드에 대해 다른 업데이트 연산자를 지정하는 업데이트는 오류를 반환합니다.

지원되는 연산자를 사용 하더라도 다음 동작이 있는 업데이트 작업은 오류를 발생시킵니다.

  • 업데이트 작업은 암호화된 경로 내부에 배열을 생성합니다.

  • 업데이트 작업은 애그리게이션 표현식 구문을 사용합니다.

결정론적 으로 암호화된 필드에 쿼리 필터 를 지정하는 업데이트 작업의 경우 쿼리 필터는 해당 필드에 지원되는 연산자 만 사용해야 합니다.

자동 클라이언트 사이드 필드 레벨 암호화 를 위해 구성된 공식 MongoDB 4.2+ 호환 드라이버는 다음 동작이 포함된 삽입 명령을 지원하지 않습니다 .

  • 암호화된 필드에 연결된 Timestamp(0,0) 가 있는 문서를 삽입하는 중입니다. (0,0) 값은 mongod 에서 타임스탬프를 생성해야 함을 나타냅니다. mongod 는 암호화된 필드를 생성할 수 없으므로 결과 타임스탬프는 암호화되지 않습니다.

  • 구성된 자동 스키마가 암호화된 _id 필드를 지정하는 경우 암호화된 _id 없이 문서를 삽입합니다. mongod 는 암호화되지 않은 ObjectId 를 자동 생성하므로 문서에서 _id 을 생략하면 자동 암호화 규칙을 준수하지 않는 문서가 생성됩니다.

  • 결정론적 으로 암호화된 필드와 연결된 배열이 있는 문서 삽입. 자동 클라이언트 사이드 필드 수준 암호화는 결정론적으로 배열을 암호화하는 것을 지원하지 않습니다.

자동 클라이언트 사이드 필드 레벨 암호화 를 위해 구성된 공식 MongoDB 4.2+ 호환 드라이버는 다음 집계 파이프라인 단계를 지원합니다.

다른 단계를 지정하는 자동 암호화로 구성된 collection에서 작동하는 집계 파이프라인이 오류를 반환합니다.

지원되는 각 파이프라인 단계에 대해 MongoDB는 지원되는 파이프라인을 통과할 때 암호화 해야 하는 필드를 추적하고 암호화 표시를 합니다.

지원되는 각 단계에서는 지원되는 쿼리 연산자애그리게이션 표현식만 지정해야 합니다.

$group 클라이언트 사이드 필드 수준 암호화와 관련하여 다음과 같은 동작이 있습니다.

  • 결정론적으로 암호화된 필드에 대한 그룹화를 지원합니다.

  • 암호화된 필드에서 산술 축적자를 지원 하지 않습니다 .

  • 암호화된 필드에서 $addToSet$push 축적자를 지원합니다. 결과 배열에서의 일치를 지원 하지 않습니다 .

Automatic client-side field level encryption supports the $lookup and $graphLookup only if the from collection matches the collection on which the aggregation runs against (i.e. 자체 조회 작업).

다른 from 컬렉션을 참조하는 $lookup$graphLookup 단계는 오류를 반환합니다.

자동 클라이언트 사이드 필드 수준 암호화를 위해 구성된 공식 4.2+ 호환 드라이버는 결정론적 으로 암호화된 필드에 대해 다음 표현식을 사용하여 애그리게이션 단계를 허용합니다.

다른 모든 애그리게이션 표현식은 암호화된 필드에 대해 실행되는 경우 오류를 반환합니다.

다음 동작을 가진 애그리게이션 단계에서는 지원되는 애그리게이션 표현식을 사용 하더라도 오류가 발생합니다.

표현식
거부된 동작
예제

$cond

$switch

표현식은 런타임이 될 때까지 암호화 속성을 알 수 없는 필드를 지정 하며 후속 애그리게이션 단계에 해당 필드를 참조하는 표현식이 포함됩니다.
$addFields : {
"valueWithUnknownEncryption" : {
$cond : {
if : { "$encryptedField" : "value" },
then : "$encryptedField",
else: "unencryptedValue"
}
}
},
{
$match : {
"valueWithUnknownEncryption" : "someNewValue"
}
}
이 표현식은 암호화된 필드를 참조하는 새 필드를 만들고 동일한 표현식의 해당 새 필드 에서 작동합니다.
{
$eq : [
{"newField" : "$encryptedField"},
{"newField" : "value"
]
}
표현식은 비교 표현식 내 암호화된 필드의 접두사를 참조합니다.
{ $eq : [ "$prefixOfEncryptedField" , "value"] }
표현식의 결과는 암호화된 필드와 비교됩니다.
{
$eq : [
"$encryptedField" ,
{ $ne : [ "field", "value" ] }
]
}
표현식이 변수를 암호화된 필드에 바인딩 하거나 $$CURRENT 리바인드를 시도합니다.
{
$let: {
"vars" : {
"newVariable" : "$encryptedField"
}
}
}

표현식의 첫 번째 인수 암호화된 필드이며 ,

  • 표현식의 두 번째 인수가 배열 리터럴이 아닙니다 .

    -또는-

  • 표현식의 두 번째 인수는 암호화된 필드입니다.

{
$in : [
"$encryptedField" ,
"$otherEncryptedField"
]
}

자동 클라이언트 사이드 필드 레벨 암호화 를 위해 구성된 공식 MongoDB 4.2+ 호환 드라이버는 다음 값 유형을 암호화해야 하는 읽기 또는 쓰기 작업을 지원하지 않습니다 .

암호화는 이러한 값에 대한 유형 정보를 적절히 숨기지 못합니다.

또한 자동 필드 수준 암호화는 암호화된 필드를 다음 값 유형과 비교하는 작업에서 결정론적 으로 필드에 대한 읽기 또는 쓰기 작업을 지원하지 않습니다.

  • double

  • decimal128

  • bool

  • object

← 자동 암호화 규칙