Docs Menu
Docs Home
/
MongoDB 매뉴얼
/ / /

db.grantRolesToUser()

이 페이지의 내용

  • 정의
  • 호환성
  • 행동
  • 필요한 액세스 권한
  • 예시
db.grantRolesToUser(username, roles, writeConcern)

사용자에게 추가 역할을 부여합니다.

db.grantRolesToUser() 메서드는 다음 구문을 사용합니다.

db.grantRolesToUser( "<username>", [ <roles> ], { <writeConcern> } )

db.grantRolesToUser() 메서드는 다음 인수를 사용합니다.

Parameter
유형
설명

user

문자열

역할을 부여할 대상이 될 사용자의 이름입니다.

roles

배열

사용자에게 부여할 추가 역할의 배열입니다.

writeConcern

문서

선택 사항. 작업에 대한 쓰기 고려 (write concern) 수준입니다. 쓰기 고려 사양을 참조하세요.

roles 필드에서 기본 제공 역할사용자 정의 역할을 모두 지정할 수 있습니다.

db.grantRolesToUser()가 실행되는 동일한 데이터베이스에 존재하는 역할을 지정하려면 역할의 이름과 함께 역할을 지정할 수 있습니다.

"readWrite"

또는 다음과 같이 문서로 역할을 지정할 수도 있습니다.

{ role: "<role>", db: "<database>" }

다른 데이터베이스에 존재하는 역할을 지정하려면 문서를 사용하여 역할을 지정합니다.

db.grantRolesToUser() 메서드는 grantRolesToUser 명령을 래핑합니다.

이 메서드는 다음 환경에서 호스팅되는 배포에서 사용할 수 있습니다.

중요

이 명령은 MongoDB Atlas 클러스터에서 지원되지 않습니다. 모든 명령에 대한 Atlas 지원 에 대한 자세한 내용은 지원되지 않는 명령을 참조하세요.

  • MongoDB Enterprise: MongoDB의 구독 기반 자체 관리 버전

  • MongoDB Community: MongoDB의 소스 사용 가능 무료 자체 관리 버전

복제본 세트에서 실행할 경우, db.grantRolesToUser()는 기본값으로 "majority" 쓰기 고려(write concern)를 사용하여 실행됩니다.

해당 데이터베이스에 역할을 부여하려면 데이터베이스에 grantRole 작업이 있어야 합니다.

다음 역할이 있는 products 데이터베이스에는 accountUser01 사용자가 지정됩니다.

"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
}
]

다음 db.grantRolesToUser() 작업은 accountUser01products 데이터베이스에 대한 readWrite 역할을 부여하고 stock 데이터베이스에 대한 read 역할을 부여합니다.

use products
db.grantRolesToUser(
"accountUser01",
[ "readWrite" , { role: "read", db: "stock" } ],
{ w: "majority" , wtimeout: 4000 }
)

이제 products 데이터베이스의 accountUser01 사용자에게는 다음 역할이 있습니다.

"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
},
{ "role" : "read",
"db" : "stock"
},
{ "role" : "readWrite",
"db" : "products"
}
]

돌아가기

db.getUsers