当前位置:首页 > 数据库 > MongoDB的安装与使用

MongoDB的安装与使用

7个月前 (05-21)60

MongoDB的安装与使用

python@ubuntu:~$ sudo apt-get install mongodb

使用MongoDB,需要先启动服务端,再使用客户端连接数据库。

服务端

MongoDB 默认的存储数据目录为 /data/db,默认端口27017
  • 服务的命令为mongod,可以通过help查看所有参数
python@ubuntu:~$ mongod --help
  • 相关文件存放路径:默认各个文件存放路径如下所示:
  • 可执行文件存放路径:/usr/bin/mongod/usr/bin/mongo
  • 数据库文件存放路径:/data/db
  • 日志文件存放路径:/var/log/mongodb/mongod.log
  • 配置文件存放路径:/etc/mongod.conf

启动注意事项:

1. 首次启动:

  • 启动MongoDB服务: sudo mongod

报出如下错误,表示默认的存储数据目录 /data/db 不存在:

[initandlisten] exception in initAndListen: 29 Data directory /data/db not found., terminating
  • 创建 /data目录和 /data/db 目录,并指定 读/写/执行 权限
python@ubuntu:~$ sudo mkdir -p /data/db
python@ubuntu:~$ sudo chmod 777 /data/db

2. 再次启动:

  • 再次启动MongoDB服务: sudo mongod

启动成功,但是可能会有如下警告:

####  Warning 1:
[initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
[initandlisten] **        We suggest setting it to 'never'
[initandlisten] 
[initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
[initandlisten] **        We suggest setting it to 'never'

####  Warning 2:
[initandlisten] ** WARNING: soft rlimits too low. rlimits set to 1024 processes, 64000 files. Number of processes should be at least 32000 : 0.5 times number of files.

####  Warning 3:
[initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.

注意:这里的三个Warning并非必须处理,大家了解即可:

Warning 1:
[initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.``[initandlisten] ** We suggest setting it to 'never'` `[initandlisten]` `[initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.` `[initandlisten] ** We suggest setting it to 'never'

Linux的内存分配默认由内核动态分配,而不是由程序自行管理。而MongoDB对内存占用有那么点…严重,所以为了防止MongoDB占用内存过大而被内核"管理",官方推荐关闭动态分配。

默认"always"表示允许动态分配,对应的"never"就是不允许,所以我们将这两个文件内容修改为"naver"后就没有warning了。

# Ctrl + c 退出 MongoDB 数据库服务
# 然后进入 root 用户下,执行修改命令

python@ubuntu:~$ sudo su
[sudo] python 的密码: 

root@ubuntu:~# sudo echo "never" > /sys/kernel/mm/transparent_hugepage/enabled
root@ubuntu:~# sudo echo "never" >  /sys/kernel/mm/transparent_hugepage/defrag

实际上,除非网站DBA对数据库性能有极限要求,在通常情况下系统动态分配的内存页大小足够我们正常使用,而且更能优化整个系统,所以一般不必理会这个warning。而且这样只是临时修改Linux内核的设置,在Linux服务器重启后则会失效。

Warning 2:
[initandlisten] ** WARNING: soft rlimits too low.` `rlimits set to 1024 processes, 64000 files. Number of processes should be at least 32000 : 0.5 times number of files.

这个WARNING(如果有的话)含义为: 表示默认分配给MongoDB的进程和文件数量限制过低,需要重新分配值:

  • mongodb当前限制:1024 processes, 64000 files
  • mongodb建议要求:processes = 0.5*files=32000(至少)

咱们学习阶段默认用不着这么多的进程和文件,所以也可以不必理会。

# 打开 相关配置文件:
root@ubuntu:~# vi /etc/security/limits.conf

# 在打开的 文件最下方,添加,然后保存退出
mongod  soft  nofile  64000
mongod  hard  nofile  64000
mongod  soft  nproc  32000
mongod  hard  nproc  32000
Warning 3:
[initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.

意思是我们在用root权限做这些事,理论上是不安全的。我们可以通过附加--auth参数,来使用用户认证来处理这个情况,这个后面会讲到。

3. 再再次启动:

  • 再再次启动MongoDB服务: sudo mongod

启动后查看进程,以确定是否启动成功

python@ubuntu:~$ ps aux | grep mongod
  • 如果进程中没有mongod的项则没有启动成功,可以通过查看日志来确定错误原因,默认日志文件为 /var/log/mongodb/mongod.log,最新的信息在最后面显示。

客户端

  • 客户端命令为 mongo,可以通过help查看所有参数。
  • 这个shell即是mongodb的客户端,用来对MongoDB进行操作和管理的交互式环境。
python@ubuntu:~$ mongo --help
  • 终端退出连接
> exit

(或Ctrl+C)

作者:徐加七
来源链接:https://blog.csdn.net/xujiaqi1998/article/details/102831466

标签: MongoDB

“MongoDB的安装与使用” 的相关文章

Java操作MongoDB

Java操作MongoDB

一、依赖和配置 1.本博客讲解SpringBoot如果快速接入MongoDB,在springBoot的基础上,添加如下依赖: <...

Linux-Ubuntu14.04下mongodb安装部署

Linux-Ubuntu14.04下mongodb安装部署

版权声明:本文为博主原创文章,未经博主允许不得转载。 前几天项目组一个紧急任务,测试服务器上搭建部署mongo并导入数据库 1.准备工作...

mongodb安装及基本的使用

mongodb安装及基本的使用

1、NoSql的概念 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,互联网的早期我们的数据大多以关系型数据库来存储的。其特点是规范的...

Mongodb安装教程  一.下载  1.1  mongodb下载  Mongodb下载地址: https://www.mongodb.com/download-center?jmp=nav#comm

Mongodb安装教程 一.下载 1.1 mongodb下载 Mongodb下载地址: https://www.mongodb.com/download-center?jmp=nav#comm

转载:http://blog.csdn.net/Clara_G/article/details/77677990 Mongodb安装教程 一.下载 1.1...

MongoDB配置参数说明

#usercenter replset master bind_ip=hadoop13 #指定服务器监听的端口,默认是27017 port=178...

linux(centos 7) 环境 mongodb 安装,配置,创建用户密码

1.下载安装包 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.2.9.t...

使用MongoDB和JSP实现一个简单的购物车系统

使用MongoDB和JSP实现一个简单的购物车系统

目录 1 问题描述  2 解决方案  2.1  实现功能  2.2  最终运行效果图 ...

【mongodb】windows上安装mongodb(详解)

【mongodb】windows上安装mongodb(详解)

windows上安装mongodb(详解) 1.下载安装包 官网下载地址:https://www.mongodb.com/try/dow...

MongoDB基本命令用

MongoDB基本命令用   成功启动MongoDB后,再打开一个命令行窗口输入mongo,就可以进行数据库的一些操作。...

MongoDB学习笔记(一)—— 安装与配置

MongoDB学习笔记(一)—— 安装与配置

1、介绍 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统,属于非关系型数据库(NoSQL)。 特点: 开发快速、极简灵活、面...