MongoDB之安装和基本使用(一)
环境
- ubuntu16.04
mongodb基本特点
MongoDB 是一个基于分布式 文件存储的NoSQL数据库;可以把MongoDB想象成一个大py字典。
- 模式自由 :可以把不同结构的文档存储在同一个数据库里
- 面向集合的存储:适合存储 JSON风格文件的形式
- 高效的传统存储方式:支持二进制数据及大型对象(如照片或图片)
安装
apt安装
sudo apt update
sudo apt install mongodb
安装完毕后mongod已经自动启动了。
apt安装会自动创建相关的配置文件
/etc/mongod.conf # mongodb的启动配置文件
/var/log/mongodb/mongod.log # 日志文件
/var/lib/mongodb # 数据文件目录
安装后会自动启动,自动设置了开机自启动。
源码安装
sudo apt-get install libcurl3 openssl
wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu1604-4.0.0.tgz # 后面可以写不同的版本
# 解压
tar -zxvf mongodb-linux-x86_64-ubuntu1604-4.0.0.tgz
# 移动
mv mongodb-linux-x86_64-ubuntu1604-4.0.0.tgz /usr/local/mongodb
# 添加到环境变量
vi ~/.bashrc
export PATH=/usr/local/mongodb/bin:$PATH
- 源码安装需要自己去创建相关的配置文件。
卸载
# 移除所有相关的安装文件
sudo apt-get purge mongodb-org*
# 移除数据文件和日志文件
sudo rm -r /var/log/mongodb
sudo rm -r /var/lib/mongodb
基本命令
# 默认监听端口port 27017
# 启动
sudo service mongodb start
# 停止
sudo service mongodb stop
# 重启
sudo service mongodb restart
# 客户端连接
mongo --host 127.0.0.1:27017
# 退出
exit
- 如果使用service命令报错:
Failed to stop mongodb.service: Unit mongodb.service not loaded.
需要手动添加mongodb.service
vi /etc/systemd/system/mongodb.service
[Unit]
Description=High-performance, schema-free document-oriented database
After=network.target
[Service]
Type=forking
User=mongodb
Group=mongodb
RuntimeDirectory=mongod
PIDFile=/var/run/mongodb/mongodb.pid
ExecStart=/usr/bin/mongod -f /etc/mongodb.conf --pidfilepath /var/run/mongodb/mongodb.pid --fork
TimeoutStopSec=5
KillMode=mixed
[Install]
WantedBy=multi-user.target
基本数据库操作
# 基本命令
db # 查看当前的数据库,默认当前数据库为test
show dbs # 查看所有的数据库
use xxx # 切换数据库,如果不存在也进入,但只有在插入了数据后才会真正地创建
db.dropDatabase() # 删除当前指向的数据库
# 创建集合
db.createCollection(name, options) # 相当于mysql的表,创建集合
name:集合的名字
options:配置参数,一个json格式文档,如:{ capped : true, size : 10 },限制集合大小
# 查看集合
show collections
# 删除集合
db.xxx(集合name).drop()
# 插入,这个创建的集合插入许多的小的json文档,类似py的字典,每个字典有一个_id,如果不指定或自动分配。
db.xxx(集合name).insert({_id:xxx,name:"xxx"})
# 查询
db.xxx(集合name).find() # 会显示集合所有文档
# 更新
db.xxx(集合name).update(
<query>, # 查询条件,类似sql语句update中where部分
<update>, # 根据查询更新字段
{multi: <boolean>} # 默认是false,表示只更新找到的第一条记录,值为true表示把满足条件的文档全部更新
)
# 保存,如果该_id存在则相当于update,如果不存在相当于insert
db.xxx(集合name).save({_id:xxx,name:"xxx"})
# 删除
db.xxx(集合name).remove(
<query>, # 查询条件
{
justOne: <boolean> # 如果设为true或1,则只删除一条,默认false,表示删除多条
}
)
数据的类型
- MongoDB和mysql一样有数据类型
Object ID:专门用于文档ID,是自动的,如果手动加文档ID,则为string类型。
String:字符串,最常用,必须是有效的UTF-8
Boolean:存储一个布尔值,true或false
Integer:整数可以是32位或64位
Double:存储浮点值
Arrays:数组或列表,多个值存储到一个键,如:{"color" : [ "red", "black" ]}
Object:用于嵌入式的文档,即一个值为一个文档,如一个图片二进制流,一篇文章
Null:存储Null值
Timestamp:时间戳
Date:存储当前日期或时间的UNIX时间格式
用户管理
mongodb默认是没有用户的,也就是说一开始是完全暴露的,可以在admin数据库中创建root用户。
- 用户的类型
root:只在admin数据库中可用,超级账号,超级权限
Read:允许用户读取指定数据库
readWrite:允许用户读写指定数据库
- 创建root用户
use admin
db.createUser({
user:'admin',
pwd:'123456',
roles:[{role:'root',db:'admin'}]
})
- 启动登录验证
# 修改配置文件/etc/mongodb.conf
# 去除注释
auth=true
# 重启mongodb
service mongoodb stop
service mongoodb start
# 输入mongo仍然可以进入数据库,但是对admin数据库没有访问权限
- 用户的登录验证
# 方法一:连接时验证
mongo -u 'admin' -p '123' --authenticationDatabase 'admin'
# 方法二:连接后验证
user admin
db.auth("admin", "123456")
- 创建普通用户
# 在任何一个位置进行操作都可以,不一定要在admin数据库下执行创建操作
db.createUser({
user:'cwp',
pwd:'passwd',
roles:[{role:'readWrite',db:'test1'}]
})
- 修改用户属性
db.updateUser('t1',{pwd:'456',roles:[{role:'Read'}]})
数据备份与恢复
# 备份数据
mongodump -h dbhost -d dbname -o dbdirectory
-h:服务器地址,也可以指定端口号,127.0.0.1:27017
-d:需要备份的数据库名称
-o:备份的数据存放位置,此目录中存放着备份出来的数据
# 恢复数据
mongorestore -h dbhost -d dbname --dir dbdirectory
-h:服务器地址
-d:需要恢复的数据库实例
--dir:备份数据所在位置
允许远程连接
vi /etc/mongodb.conf
#允许局域网连接
bind_ip=127.0.0.1,192.168.1.2
# 允许公网连接
bind_ip=127.0.0.1,192.168.1.2,公网ip
MongoDB之安装和基本使用(一)的更多相关文章
- MongoDB下载安装与简单增删改查
Windows下MongoDB的安装和配置.启动和停止 下载地址:MongoDB的官方下载网址是:https://www.mongodb.org/downloads 安装步骤1. 点击下载的mongo ...
- MongoDB的安装与设置MongoDB服务
Mongo DB 是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式备受当前IT从业人员的青睐.Mongo DB很好的实现了面向对象的思想(OO思想),在Mongo DB ...
- Linux下MongoDB服务安装
Linux下MongoDB服务安装 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案.MongoDB是一个介于关系数据库和非关系数据 ...
- MongoDB学习-安装流程
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. 支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型. ...
- mongodb(二) 安装和使用
mongodb的安装和使用 最近的项目需要使用到mongodb,从而开始熟悉nosql,有了本篇文章,记录和方便他人. mongodb的安装 下载地址:http://www.mongodb.org/d ...
- MongoDB的安装及配置
MongoDB 是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式备受当前IT从业人员的青睐. Windows (1). 登录Mongodb官网点击下载 (2). 将zi ...
- MongoDB的安装 转
第1章 MongoDB的安装 (黎明你好原创作品,转载请注明) 1.1 MongoDB简介 MongoDB是一个基于分布式文件存储的数据库开源项目.由C++语言编写,旨在为WEB应用提供可护展的高性能 ...
- MongoDB的安装,配置与开机自启动
关于简介不多说百度去吧少年.. MongoDB详细安装: 1.进入官网,点击DOWNLOAD MONGODB,下载所需要的版本.. 我这里把下载的文件放在d\MongoDB文件夹下,点击下载的官方镜像 ...
- MongoDB(二)——安装配置了解
前边介绍了MongoDB的大概理论知识,这篇来对MongoDB进行一下安装使用,支持安装在windows和linux上,当然了很多其它情况下我们是安装在linux上,由于毕竟server用linux的 ...
- MongoDB本地安装与启用(windows )
MongoDB的安装与MongoDB服务配置 Mongo DB 是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式备受当前IT从业人员的青睐.Mongo DB很好的实现了 ...
随机推荐
- 【bzoj4487】[Jsoi2015]染色问题 容斥原理
题目描述 棋盘是一个n×m的矩形,分成n行m列共n*m个小方格.现在萌萌和南南有C种不同颜色的颜料,他们希望把棋盘用这些颜料染色,并满足以下规定: 1. 棋盘的每一个小方格既可以染色(染成C种颜色中 ...
- 【bzoj5123】[Lydsy12月赛]线段树的匹配 树形dp+记忆化搜索
题目描述 求一棵 $[1,n]$ 的线段树的最大匹配数目与方案数. $n\le 10^{18}$ 题解 树形dp+记忆化搜索 设 $f[l][r]$ 表示根节点为 $[l,r]$ 的线段树,匹配选择根 ...
- 【服务器_Tomcat】Tomcat的Server Options选项
一.配置 默认前两个是没有勾选的,应该勾选上: 在Cotext节点中有一个reloadable='true'属性,将它改为false,可以在修改java文件后不用重启服务器即可生效,但是不包括新建ja ...
- C++解析(20):智能指针与类型转换函数
0.目录 1.智能指针 2.转换构造函数 3.类型转换函数 4.小结 1.智能指针 内存泄漏(臭名昭著的Bug): 动态申请堆空间,用完后不归还 C++语言中没有垃圾回收机制 指针无法控制所指堆空间的 ...
- 学Python Django学得很迷茫,怎么办?-转自知乎
本人学生,零编程基础,在学习python的过程中越学越迷茫,感觉像无头苍蝇一样,来知乎取经,下面进入正题吧: 我是先看了中谷的python教学视频,然后跟着慕课网上的python教程把题 ...
- 待续--mysql中key 、primary key 、unique key 与index区别
mysql中key .primary key .unique key 与index区别
- QT创建模态对话框阻塞整个应用程序和非模态对话框唯一性约束的简单示例
QT创建模态对话框阻塞整个应用程序和非模态对话框唯一性约束的简单示例 部分代码: // 创建模态对话框阻塞整个应用程序和非模态对话框唯一性约束 QMenu *pDialog = mBar->ad ...
- Android 解决ScrollView嵌入ListView | GridView | ScrollView显示问题
一.ScrollView中嵌套ListView ScrollView和ListView都是滚动结构,很明显如果在ScrollView中加入ListView,可以预见性的知道,肯定会有显示/滚动的问题, ...
- 【BZOJ4455】小星星(动态规划,容斥)
[BZOJ4455]小星星(动态规划,容斥) 题面 BZOJ 洛谷 Uoj 题解 题意说简单点就是给定一张\(n\)个点的图和一棵\(n\)个点的树,现在要让图和树之间的点一一对应,并且如果树上存在一 ...
- MSSQL DBA权限获取WEBSHELL的过程
前言 本文主要通过一个案例来演示一下当MSSQL是DBA权限,且不知道路径的时候如何去获取WEBSHELL.当然这种方式对站库分离的无效.我测试的环境是在Win7 64位下,数据库是SQLServer ...