zoukankan      html  css  js  c++  java
  • Windows下MongoDB安装及创建用户名和密码

    下载MongoDB的安装文件https://www.mongodb.com/download-center#community,选择合适的版本(注:本人选择的是3.2.6)

    下载完MongoDB.msi后点击Next一路安装下去(注:本人的mongodb的安装路径为D:MongoDBServer

    将MongoDB服务器作为Windows服务运行
    请注意,你必须有管理权限才能运行下面的命令。执行以下命令将MongoDB服务器作为Windows服务运行:

    mongod.exe --bind_ip 127.0.0.1 --logpath "D:MongoDBServermglogsmongodb.log" --logappend --dbpath "D:MongoDBServerdb" --serviceName "mongodb" --serviceDisplayName "mongodb" --auth --install    (注:加上--auth 这样以后就可以使用用户名和密码后才能进行MongoDB的相关操作)

    上述命令运行成功后,开始—>运行—>输入services.msc 回车后就可以打开 windows 所有的服务项列表 ;在列表中就可以查看到mongodb的服务项,点击启动。

    --------------------------------------------------------------------------------------------------------------------------

    启动完MongoDB后,cmd命令下进入D:MongoDBServerin(即MongoDB的安装目录),执行mongo.exe;

    上面提到过为了MongoDB的安全,我们必须通过用户名和密码登陆后才能操作MongoDB,现在增加一个管理员:

    use admin  注:MongoDB安装好以后由默认的admin表和local表;其中admin存放的是用户信息

    db.createUser({ user: "root",pwd: "root",customData:{name:"root"},roles:[{ role: "userAdminAnyDatabase",db: "admin" }]}) 注:创建一个用户名和密码为root的管理员

    创建完后登陆

    db.auth('root','root')

    show collections


    --------------------------------------------------------------------------------------------------------------------------

    createUser 方法 db.createUser( { user: "accountAdmin01",
    pwd: "changeMe",
    customData: { employeeId: 12345 },
    roles: [ { role: "clusterAdmin", db: "admin" },
    { role: "readAnyDatabase", db: "admin" },
    "readWrite"] },
    { w: "majority" , wtimeout: 5000 } )

    customData 用户信息备注

    roles 用户角色:
    1. 数据库用户角色:read、readWrite;
    2. 数据库管理角色:dbAdmin、dbOwner、userAdmin;
    3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
    4. 备份恢复角色:backup、restore;
    5. 所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
    6. 超级用户角色:root

    > 创建一般用户,也是用createUser

    use db01db.createUser({user:"oneUser",pwd:"12345",roles:[{role:"read",db:"db01"},{role:"read",db:"db02"},{role:"read",db:"db03"}]})


    > 创建一个不受访问限制的超级用户 use admindb.createUser({user:"superuser",pwd:"pwd",roles:["root"] })

    --------------------------------------------------------------------------------------------------------------------------

    修改用户密码

    use admin
    db.changeUserPassword("username", "xxx")


    --------------------------------------------------------------------------------------------------------------------------

    查看用户信息
    db.runCommand({usersInfo:"userName"})

    --------------------------------------------------------------------------------------------------------------------------

    修改密码和用户信息
    db.runCommand( { updateUser:"username", pwd:"xxx", customData:{title:"xxx"} })

    注意:和用户管理相关的操作基本都要在admin数据库下运行,要先use admin;

  • 相关阅读:
    使用ServiceLoader辅助责任链模式
    聊聊ThreadLocal
    Log4J
    Scalable IO in Java
    MySQL的索引
    Git的操作与理解
    阿里校招内推总结
    Executor框架的简要分析
    Java 8 中的ConcurrentHashMap源码分析
    从C#到Swift,Swift学习笔记
  • 原文地址:https://www.cnblogs.com/itxiongwei/p/5520690.html
Copyright © 2011-2022 走看看