MongoDB 学习之从入门到放弃

一 前期准备

1.1 简介

MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。

在高负载的情况下,添加更多的节点,可以保证服务器性能。

MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。

 1.2 主要特点

  • MongoDB 是一个面向文档存储的数据库,操作起来比较简单和容易。
  • 你可以在MongoDB记录中设置任何属性的索引 (如:FirstName="Sameer",Address="8 Gandhi Road")来实现更快的排序。
  • 你可以通过本地或者网络创建数据镜像,这使得MongoDB有更强的扩展性。
  • 如果负载的增加(需要更多的存储空间和更强的处理能力) ,它可以分布在计算机网络中的其他节点上这就是所谓的分片。
  • Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。
  • MongoDb 使用update()命令可以实现替换完成的文档(数据)或者一些指定的数据字段 。
  • Mongodb中的Map/reduce主要是用来对数据进行批量处理和聚合操作。
  • Map和Reduce。Map函数调用emit(key,value)遍历集合中所有的记录,将key与value传给Reduce函数进行处理。
  • Map函数和Reduce函数是使用Javascript编写的,并可以通过db.runCommand或mapreduce命令来执行MapReduce操作。
  • GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件。
  • MongoDB允许在服务端执行脚本,可以用Javascript编写某个函数,直接在服务端执行,也可以把函数的定义存储在服务端,下次直接调用即可。
  • MongoDB支持各种编程语言:RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
  • MongoDB安装简单。

1.3 历史

  • 2007年10月,MongoDB由10gen团队所发展。2009年2月首度推出。
  • 2012年05月23日,MongoDB2.1 开发分支发布了! 该版本采用全新架构,包含诸多增强。
  • 2012年06月06日,MongoDB 2.0.6 发布,分布式文档数据库。
  • 2013年04月23日,MongoDB 2.4.3 发布,此版本包括了一些性能优化,功能增强以及bug修复。
  • 2013年08月20日,MongoDB 2.4.6 发布。
  • 2013年11月01日,MongoDB 2.4.8 发布。
  • ……

1.4 下载安装包

下载地址:https://www.mongodb.com/try/download/community

  • OS X 32-bit
  • OS X 64-bit
  • Linux 32-bit
  • Linux 64-bit
  • Windows 32-bit
  • Windows 64-bit
  • Solaris i86pc
  • Solaris 64

 1.5 上传安装包

把下载的安装包上传到服务器指定目录,然后通过 tar -zxvf xxxx解压,如果觉得名字太长,可以重新命名。

# 解压 
tar -zxvf mongodb-linux-x86_64-rhel70-4.4.10.tgz

# 重新命名
mv mongodb-linux-x86_64-rhel70-4.4.10 mongodb

二 安装

2.1 创建目录

  • 创建数据目录:mkdir -p /opt/data6/mongodb/data/db
  • 创建日志目录:mkdir -p /opt/data6/mongodb/logs
  • 创建日志文件:touch /opt/data6/mongodb/logs/mongodb.log

2.2 启动

2.2.1 前台启动

bin/mongod --dbpath /opt/data6/mongodb/data/db --logpath /opt/data6/mongodb/logs/mongodb.log --logappend --port 27017 --bind_ip 0.0.0.0
  • --dbpath:指定数据文件存储目录
  • --logpath:指定日志存储文件
  • --logappend:使用追加的方式记录日志
  • --port:指定端口,默认27017
  • --bind_ip:绑定服务IP,让非本机都可以连接

在mongo目录下执行,就可以测试连接:bin/mongo

2.2.2 后台启动

bin/mongod --dbpath /opt/data6/mongodb/data/db --logpath /opt/data6/mongodb/logs/mongodb.log --logappend --port 27017 --bind_ip 0.0.0.0 --fork
  • --fork:后台启动

2.2.3 配置文件启动

前台和后台启动命令太多,不常用记住不容易,可以使用配置文件方式。

在bin目录下创建文件夹:vim mongodb.conf 添加一下配置。

#数据文件存储目录
dbpath = /opt/data6/mongodb/data/db
#日志文件存储目录
logpath = /opt/data6/mongodb/logs/mongodb.log
#以追加方式记录日志
logappend = true
#端口,默认为27017
port = 27017
#对访问ip地址不做限制,默认限制本地地址
bind_ip = 0.0.0.0
#以守护进程方式启动,后台启动
fork = true

使用配置文件启动

bin/mongod -f bin/mongodb.conf

使用配置文件停止

bin/mongod -f bin/mongodb.conf --shutdown

设置环境变量,这样在启动或者停止的时候就不用在去mongodb bin目录下执行命令

 配置环境变量后,启动或者停止直接:mongod -f xxxxxx,不用进入bin下面,在前面加bin/

三 使用shell命令连接访问

3.1 连接mongodb

bin/mongo

3.2 显示所有数据库的列表

show dbs

3.3 显示当前数据库对象或集合

db

3.4 连接到一个指定的数据库

 use local

3.5 帮助命令

help

3.6 查看版本

db.version()

四 用户与权限管理

4.1 创建管理员用户

4.1.1 切换用户与查看用户

# 查看数据库
show dbs
# 切换到admin用户
use admin
# 查看用户,初始化是没有用户的,需要我们创建
show users

4.1.2 创建用户

db.createUser({user:"admin",pwd:"admin123",roles:[{role:"userAdminAnyDatabase",db:"admin"}]})
  • user:用户名
  • pwd:密码
  • roles:数组类型,配置用户的权限

4.1.3 修改启动参数,可以加载配置文件中

4.1.4 重启服务

# 停止
bin/mongod -f bin/mongodb.conf --shutdown
# 启动
bin/mongod -f bin/mongodb.conf

4.1.5 验证身份认证

# 连接查看什么也看不到
show dbs
# 切换到admin用户
use admin
# 使用用户和密码连接,返回1表示成功可使用show dbs,查看数据库了,返回0表示失败,
db.auth("admin","admin123")

4.2 创建普通用户

普通用户就是指只有一定范围权限的用户,比如:我创建一个test数据库,给这个test创建一个专属用户testuser,密码是testuser123,并给这个用户添加该数据库的读写操作权限。

4.2.1 管理员登录数据库

普通用户由管理员创建,所以先使用管理员用户登录数据库。

4.2.2 创建数据库

mongdb没有特定创建数据库的语法,在使用use切换用户时,如果该数据库不存在则创建并切换。

use test

4.2.3 创建普通用户

db.createUser({user:"testuser",pwd:"testuser123",roles:[{role:"readWrite",db:"test"}]})

4.2.4 验证身份认证

打开一个新的客户端,切换到test数据库,使用testuser登录,执行一条插入语句,返回信息:

# 切换到test数据库
use test
# 身份认证
db.auth('testuser',testuser123)
# 执行插入语句
db.user.insert({'id':1,'name':'张三','age':20})
# 查看插入数据
db.user.find()

4.3 更新用户

4.3.1 更新权限

比如:给刚才创建的 tseruser 添加userAdmin 权限。

db.updateUser("testuser",{"roles:[{"role":"readWrite",db:"test"},{role:"userAdmin",db:"test"}]})

4.3.2 更新密码

这这种都可以更改要不过户密码

  • db.updateUser("用户名",{"pwd"},"新密码")
  • db.changeUserPassword("用户名",{"pwd"},"新密码")

4.4 删除用户

db.dropUser("用户名")

五 数据库操作 

5.1 创建数据库

use 命令表示切换到数据库,如果数据库不存在就创建。

# user 数据库名

5.2 显示数据库

通过 show dbs 或者 show databases 查看数据库

注意:

  • 不同角色看见的数据库是不一样,管理员看见所有数据,普通用户只能看见自己的数据库。
  • 新创建数据库里面没有数据时通过 show dbs 或者 show databases 是无法查看到的。需要想数据库新增一个document(db.jpkinsert({"key":"value"}))才能看见,因为是懒加载,没有数据看不到。

5.3 删除数据库

删除数据库需要切换到需要删除的数据库中,且登录用户具有dbAdminAndDatabase权限,通过执行 db.dropDatabase() 命令删除。

六 集合操作

6.1 创建集合

mongdb 使用 db.createCollection 函数来创建集合。在 mongoDB 中,你不需要创建集合。当你插入一些文档时,mongoDB 会自动创建集合。
语法格式:db.createCollection(name, options)

6.2 显示集合

如果要查看已有集合,可以使用 show collections 或 show tables 命令查看。

6.3 删除集合

db.collection.drop()

如果成功删除选定集合,则 drop() 方法返回 true,否则返回 false。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

十点摆码

有用你就打赏一下

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值