Node.js & MongoDB

사용자 계정 관리

몽고DB를 시동하고 나서 가장 먼저 해야 할 일은 데이터베이스에 접근할 수 있도록 사용자를 추가하는 것이다.

사용자 목록 출력

사용자 계정은 각 데이터베이스의 db.system.users 컬렉션에 저장된다. User 객체에는 id, user, pwd, roles 그리고 가끔 otherDBRoles 필드가 있다.

다음은 admin 데이터베이스로 변경한 다음 사용자 목록을 출력한다.

use admin
show users

다음 코드는 admin 데이터베이스 내 사용자의 커서를 얻고, 사용자의 수를 반환한다.

use admin
cur = db.system.users.find()
cur.count()

사용자 계정 생성

몽고DB 셸 내부에서 addUser() 메소드를 사용해서 사용자 계정을 추가한다. createUser() 메소드는 해당 사용자의 사용자 이름, 권한, 그리고 비밀번호를 명시할 수 있는 document 객체를 받는다.

다음은 document 객체에 명시할 수 있는 필드 목록이다.

  • user, roles, pwd, userSource, otherDBRoles

사용자를 생성하려면, 해당 데이터베이스로 전환한 다음 createUser() 메소드를 사용해서 user 객체를 생성해야 한다. 다음 몽고DB 셸 명령은 test 데이터베이스에 대한 기본적인 관리자 계정을 생성하는 방법을 보여준다.

use test
db.createUser( {use: "testUser", 
    pwd: "test", 
    roles: ["readWrite", "dbAdmin"] } )

다음 명령은 read 권한만 갖고 있는 동일한 사용자를 admin 데이터베이스에 추가하고 testDB2 데이터베이스에 대한 readWrite 권한을 부여한다.

use admin
db.createUser( {user: "testUser", 
    userSource: "test", 
    roles: ["read"], 
    otherDBRoles:{ testDB2: ["readWrite"] } } )

사용자 삭제

dropUser(<username>) 메소드를 사용해서 몽고DB로부터 사용자를 삭제할 수 있다. 먼저 해당 사용자가 있는 데이터베이스로 변경해야 한다. 예를 들면, testDB 데이터베이스의 testUser 사용자를 삭제하려면, 다음 명령을 사용한다.

use testDB
db.dropUser("testUser")