NoSQL之mongodb

NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL"。

指的是非关系型的数据库,是对不同于传统的关系型数据库的数据库管理系统的统称。

NoSQL用于超大规模数据的存储。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。

回顾一下关系型数据库遵循ACID规则:

事务transaction,和现实世界中的交易很类似,它有如下四个特性:

1、A (Atomicity) 原子性

原子性很容易理解,也就是说事务里的所有操作要么全部做完,要么都不做,事务成功的条件是事务里的所有操作都成功,只要有一个操作失败,整个事务就失败,需要回滚。

例如银行转账,从A账户转100元至B账户,分为两个步骤:1)从A账户取100元;2)存入100元至B账户。这两步要么一起完成,要么一起不完成,如果只完成第一步,第二步失败,钱会莫名其妙少了100元。

2、C (Consistency) 一致性

一致性也比较容易理解,也就是说数据库要一直处于一致的状态,事务的运行不会改变数据库原本的一致性约束。

例如现有完整性约束a+b=10,如果一个事务改变了a,那么必须得改变b,使得事务结束后依然满足a+b=10,否则事务失败。

3、I (Isolation) 独立性

所谓的独立性是指并发的事务之间不会互相影响,如果一个事务要访问的数据正在被另外一个事务修改,只要另外一个事务未提交,它所访问的数据就不受未提交事务的影响。

例如现有有个交易是从A账户转100元至B账户,在这个交易还未完成的情况下,如果此时B查询自己的账户,是看不到新增加的100元的。

4、D (Durability) 持久性

持久性是指一旦事务提交后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。

两者的特性:

RDBMS

- 高度组织化结构化数据

- 结构化查询语言(SQL)

- 数据和关系都存储在单独的表中

- 数据操作语言,数据定义语言

- 严格的一致性

- 基础事务

NoSQL

- 不仅仅是SQL

- 没有声明性查询语言

- 没有预定义的模式

- 键 - 值对存储,列存储,文档存储,图形数据库

- 最终一致性,而非ACID属性

- 非结构化和不可预知的数据

- CAP定理

- 高性能,高可用性和可伸缩性



mongodb 入门

一、安装配置:

1.下载安装包并解压到指定安装目录

mkdir /opt/soft/ && cd /opt/soft
curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.4.9.tgz 
mkdir /opt/mongodb
tar zxvf mongodb-linux-x86_64-3.4.10.tgz
mv mongodb-linux-x86_64-3.4.10/* /opt/mongodb/

2.添加环境变量:

MongoDB 的可执行文件位于 bin 目录下,所以可以将其添加到 PATH 路径中:

 echo "export PATH=/opt/mongodb/bin:$PATH">>/etc/profile && source /etc/profile

3.创建conf文件夹用于存放配置文件,创建data文件夹用于存放数据,创建logs文件用于存放文件,这些目录在安装过程不会自动创建,都要手动创建。

mkdir /opt/mongodb/conf
mkdir /opt/mongodb/data
mkdir /opt/mongodb/logs
touch /opt/mongodb/conf/mongodb.conf
touch /opt/mongodb/logs/mongod.log

4、编辑配置文件

vi /opt/mongodb/conf/mongodb.conf

dbpath = /opt/mongodb/data
logpath = /opt/mongodb/logs/mongod.log
pidfilepath = /opt/mongodb/mongo.pid
port = 27017
fork = true

5、MongoDB设置为系统服务并且设置开机启动

vi   /etc/init.d/mongod

#!/bin/sh  
#description: mongodb  
start() {
 /opt/mongodb/bin/mongod -f /opt/mongodb/conf/mongodb.conf
}
stop() {
 /opt/mongodb/bin/mongod -f /opt/mongodb/conf/mongodb.conf --shutdown
}
case "$1" in
  start)
 start
 ;;
  stop)
 stop
 ;;
  restart)
 stop
 start
 ;;
  *)
 echo $"Usage: $0 {start|stop|restart}"  
 exit 1
esac

chmod +x /etc/rc.d/init.d/mongod

6、启动

service mongod start

二、用户授权和管理

1、mongodb安装好后第一次进入是不需要密码的,也没有任何用户,通过shell命令可直接进入,cd到mongodb目录下的bin文件夹,执行命令./mongo即可

 ./mongo
 MongoDB shell version v3.4.9
 connecting to: mongodb://127.0.0.1:27017
 MongoDB server version: 3.4.9
 > show dbs
 admin  0.000GB
 local  0.000GB
 > use test
 switched to db test
 >

2、添加管理用户(mongoDB 没有无敌用户root,只有管理用户的用户 userAdminAnyDatabase)

> use admin 
switched to db admin
> db.createUser({user:"admin",pwd:"123456",roles:[{role:"userAdminAnyDatabase",db:"admin"}]})

Successfully added user: {

"user" : "admin",

"roles" : [

{

"role" : "userAdminAnyDatabase",

"db" : "admin"

}

]

}

3、添加完管理用户后,关闭MongoDB,并使用权限方式再次开启MongoDB,这里注意不要使用kill直接去杀掉mongodb进程,(如果这样做了,请去data/db目录下删除mongo.lock文件),可以使用db.shutdownServer()关闭。

4、修改配置文件,开启密码验证登录

vi /opt/mongodb/conf/mongodb.conf

auth = true #开启
service mongod start

5、进入mongo shell,使用admin数据库并进行验证,如果不验证,是做不了任何操作的

> use admin
> db.auth("admin","123456")
1 #认证返回1表示成功
>

6、验证之后还是做不了操作,因为admin只有用户管理权限,下面创建用户,用户都跟着库走

> use mytest
switched to db mytest
> db.createUser({user: "root",pwd: "123456",roles: [{ role: "readWrite", db: "mytest" }]})

Successfully added user: {

"user" : "root",

"roles" : [

{

"role" : "readWrite",

"db" : "mytest"

}

]

}

7、使用创建的用户root登录进行数据库操作

[[email protected] ~]# mongo 127.0.0.1/mytest -uroot -p
MongoDB shell version v3.4.10
Enter password: 
connecting to: mongodb://127.0.0.1/mytest
MongoDB server version: 3.4.10
> db
mytest
> use mytest
switched to db mytest
> show collections
>
时间: 2024-10-16 14:27:44

NoSQL之mongodb的相关文章

nosql数据库MongoDB的用法

MongoDB常用命令 1.启动命令 mongod 启动数据库进程 --dbpath 制定数据库的目录 --port 制定数据库的端口,默认是27017 --bind_ip 绑定IP --directoryperdb 为每个db创建一个独立子目录 --logpath 制定日志存放目录 --logappend 指定日志生成方式(追加/覆盖) 例如:mongod --dbpath db --port 27098 --directoryperdb --logpath db\logs\mongodb.l

Linux系统安装NoSQL(MongoDB和Redis)步骤及问题解决办法

?更多技术干货请戳:听云博客 如下是我工作中的记录,介绍的是linux系统下NoSQL:MongoDB和Redis的安装过程和遇到的问题以及解决办法: 需要的朋友可以按照如下步骤进行安装,可以快速安装MongoDB和Redis,希望可以帮助大家:)! 一.MongoDB 1.MongoDB安装 (1)将安装包mongodb-linux-i686-3.0.2.tgz拷贝到要安装的服务器中 这里我用的rz命令,如果不支持需要安装yum -y install lrzsz (2)解压安装程序 tar x

Nosql and Mongodb 介绍

Nosql兴起的背景: 1)web2.0兴起(高交互性),传统的关系型数据库为了保证"通用性"的设计而带来 了功能复杂,性能开销大,和价格昂贵的问题. 2)避免不必要的复杂性 3)更高的吞吐量和高并发 4)在商用硬件上的水平扩展能力 5)Nosql实现大表自动切割,更有利于支持分布式处理 6)在性能和安全方面做了折中(有时不需要sql的很高的安全性) 7)云计算的需求(从中心模式转到分布模式) 各种主流Nosql数据库:                 1)memcached数据库:m

nosql之mongodb简单安装与命令使用

nosql:非关系型,分布式,不提供ACID 简单数据模型 元数据和应用数据分离 弱一致性 优势: 避免不必要的复杂性 高吞吐量 高水平扩展能力和低端硬件集群 不使用对象-关系映射 劣势: 不支持ACID特性 功能简单 没有统一的数据查询模型 ACID:atomicity原子性.consistency一致性.isolation隔离.durability持久性 nosql分类: 列式数据库(按列管理) 键值存储 文档数据库(每一行当做一个实体,独立的文件) 图存数据库(有复杂关系的图存对象),在社

Mongodb入门系列(1)——NoSQL及MongoDB的特性

NoSQL,是Not Only SQL的缩写,可不是no SQL哦. NoSQL目前被国内外的很多公司在应用: 新浪微博  Redis Google  BIgtable Amazon  SimpleDB 淘宝数据平台 Tair 视觉中国网站 MongoDB youku运营数据中心 MongoDB 飞信空间 HandlerSocket 豆瓣 BeansDB NoSQL数据库关注的是对数据高并发地读写和对海量数据的存储等,与关系型数据库相比,NoSQL数据库在结构和数据模型方面做"减法",

使用NOSQL的MongoDB时建立索引需要注意的几点建议和Explain优化分析

第一,MongoDB索引和MySQL索引非常相似并且对于MySQL的索引优化有很多也适用于MongoDB. 第二,更重要的是,这些索引的建立对你的应用提高也是有限的. 对于应用的最佳索引策略应该基于很多的重要因素.包含了你期望查询的类型, 数据读取与写入的比率,甚至于你服务器的空闲内存.意思就是, 需要对线上的产品做很多的测试剖析工作,才能调整出最佳的索引策略. 没有什么好的方法可以替代实际经验的. 索引策略 下面有些索引的基本法则 创建的索引要匹配查询. 如果你仅仅要查询单个字段.索引这个字段

Nosql中MongoDB的介绍

一.MongoDB的认识 基本简介 mongodb是一种介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的,语法有点类似javascript面向对象的查询语言,它是一个面向集合的,模式自由的文档型数据库,MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成.MongoDB 文档类似于 JSON 对象.字段值可以包含其他文档,数组及文档数组 mongodb概念解析 文档 文档是mongodb中数据的基本单元,类似关系数据库的行,多个

NoSQL数据库 -- MongoDB

终于下定决心在某东购买了<python核心编程(二)>和<鸟哥linux,基础 (三)>.感觉学习linux最开始还是在虚拟机里面比较好,所以安装了VirtualBox,并下载了Cent OS 7. 安装完Cent OS发现完全没GUI啊,还好之前用了段时间的Ubuntu,感觉还好. (一) windows系统下面的安装 (1)下载,官网是 http://www.mongodb.org/ 不要去了 com那个.下载的2.4稳定版. (2)下载zip文件,然后解压.在D盘新建mong

NoSql之Mongodb日常操作命令整理

1.db.serverStatus()  看看分片性能信息 db.serverStatus().connections;分片查看客户端连接数,mongod和mongos的连接属于长连接 "connections" : {                "current" : 737, --当前活动连接量.连接到server的当前活跃连接数目                "available" : 82 --剩余空闲连接量.剩余的可用连接数目