注:文档使用pc环境为linux、ubuntu14。安装的mongodb版本号为2.4.9
**1. mongo的安装 **
执行sudo apt-get install mongodb
即可安装完成。若无法安装可尝试修改linux安装源。以下为aliyun的源,可供参考:
deb http://mirrors.163.com/ubuntu/ intrepid main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ intrepid-security main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ intrepid-updates main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ intrepid-proposed main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ intrepid-backports main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ intrepid main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ intrepid-security main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ intrepid-updates main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ intrepid-proposed main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ intrepid-backports main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty-proposed main restricted universe multiverse
**2. mongodb的启动 **
执行service mongodb start
即启动mongodb服务
**3. 本地连接mongodb **
shell界面输入mongo即可进入mongo的交互模式。若输入mongo后没有进入mongo的交互模式,则上一步的mongdb启动失败。具体操作按照错误进行适当尝试或百度。
进入交互模式后,可执行mongodb的命令,具体命令有:
# 显示所有数据库
show dbs
# 显示当前数据库中的所有数据集合,类似于mysql等关系数据库中的表
show collections
# 显示当前数据库的所有用户信息
show users
# 使用dbname这个数据库,意思就是接下来的操作都是在这个数据库上
use [dbname]
# 向当前数据库添加名称为namemima为pwd权限为readonly=false的用户
db.addUser("[name]", "[pwd]", false) # 仅当开启了权限认真后才有作用
# 验证身份(若开启了身份验证则需要此 )
db.auth("[name]", "[pwd]")
# 删除数据库
db.dropDatabase()
# 删除表(集合)
db.[table].drop()
# 插入数据
db.[table_name].insert({"key": "value"})
# 查找数据
db.[table_name].find({"key": "value"})
# 删除数据
db.[table_name].remove({"key": "value"})
# 修改数据
db.[table_name].update({"key": "value"}, {"key": "new_value"})
**4. 开启权限验证 **
mongodb默认未开启权限认证功能。所以需要修改/etc/下的配置文件mongodb.conf中被注释掉的#auth=true为auth=true(就是删掉#号)
修改完成后,重启mongodb即可生效。
**5. 开启远程连接 **
若要开启允许远程连接,则需要修改配置文件。把其中的bind_ip=127.0.0.1更改为bind_ip=0.0.0.0
然后重启mongodb即可生效
**6. 关于用户权限 **
当配置中开启了auth=true之后,若没有通过db.auth(name, pwd)的验证,那么将不能操作数据库。
对应的,有一个admin权限的用户表,位于admin数据库中。有的版本可能不会默认有admin数据库,那么可以使用use admin然后db.addUser("[name]", "[pwd]")即可添加一个管理员用户。重启mongodb后方可生效。admin用户具有其他数据库的操作权限。但反之,其他数据库登录的用户不具有非自身