MongoDB 简介
MongoDB是一个基于分布式文件存储 [1] 的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:
- 面向集合存储,易存储对象类型的数据。
- 模式自由。
- 支持动态查询。
- 支持完全索引,包含内部对象。
- 支持查询。
- 支持复制和故障恢复。
- 使用高效的二进制数据存储,包括大型对象(如视频等)。
- 自动处理碎片,以支持云计算层次的扩展性。
- 支持 Golang,RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
- 文件存储格式为BSON(一种JSON的扩展)。
- 可通过网络访问。
1、查看可用的MongoDB版本
访问MongoDB镜像库地址:https://hub.docker.com/_/mongo?tab=tags&page=1
可以通过Sort by查看其他版本的MongoDB,默认是最新版本mongo:latest。
你也可以在下拉列表中找到其他你想要的版本:
2、查看mongodb可用版本
[root@localhost ~]# docker search mongodb
3、获取最新版的MongoDB镜像
这里我们拉取官方的最新版本的镜像
[root@localhost ~]# docker pull mongo:latest
4、查看本地镜像
使用以下命令来查看是否已安装了mongo
[root@localhost ~]# docker images
在上图中可以看到我们已经安装了最新版本(latest)的mongo镜像
5、运行容器
安装完成后,我们可以使用以下命令来运行mongo容器
[root@localhost ~]# docker run -itd --name mongo -p 27017:27017 mongo --auth
d7b2b7a3388f388cb879ce00a67f8093e879845994622a5ab14a7f54665a1b37
参数说明:
-p 27017:27017:映射容器服务的27017端口到宿主机的27017端口。外部可以直接通过宿主机ip:27017访问到mongo的服务。
--auth:需要密码才能访问容器服务。
6、查看容器运行情况
[root@localhost ~]# docker ps -a
接着使用以下命令添加用户和设置密码,并且尝试连接。
[root@localhost ~]# docker exec -it mongo mongo admin
创建用户名为admin,密码为123456
> db.createUser({ user:'admin',pwd:'123456',roles:[ { role:'userAdminAnyDatabase', db: 'admin'}]});
尝试使用上面创建的用户信息进行连接。
> db.auth('admin','123456')
历史上的今天
6 月
19