创建仓库文件:

1
vi /etc/yum.repos.d/mongodb-org-3.4.repo

然后复制下面配置,保存退出

1
2
3
4
5
6
[mongodb-org-3.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc

yum安装

1
yum install -y mongodb-org
没有权限就在前面加: sudo
安装完毕后修改配置文件:
1
vi /etc/mongod.conf

mongod.conf 文件内容

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# mongod.conf

# for documentation of all options, see:
# http://docs.mongodb.org/manual/reference/configuration-options/

# where to write logging data.
systemLog:
destination: file
logAppend: true
path: /home/mongoDb/log/mongod.log

# Where and how to store data.
storage:
dbPath: /home/mongoDb/data/db
journal:
enabled: true
# engine:
# mmapv1:
# wiredTiger:

# how the process runs
processManagement:
fork: true # fork and run in background
pidFilePath: /var/run/mongodb/mongod.pid # location of pidfile
timeZoneInfo: /usr/share/zoneinfo

# network interfaces
net:
port: 27017
bindIp: 0.0.0.0 # Enter 0.0.0.0,:: to bind to all IPv4 and IPv6 addresses or, alternatively, use the net.bindIpAll setting.


security:
authorization: enabled

#operationProfiling:

#replication:

#sharding:

## Enterprise-Only Options

#auditLog:

#snmp:

修改配置文件的 bind_ip, 默认是 127.0.0.1只限于本机连接。所以安装完成后必须把这个修改为 0.0.0.0 ,否则通过别的机器是没法连接的!

启动、停止、重启

MongoDB默认将数据文件存储在/var/lib/mongo目录,默认日志文件在/var/log/mongodb中。如果要修改,可以在 /etc/mongod.conf 配置中指定备用日志和数据文件目录。

启动命令:

1
service mongod start

停止命令:

1
service mongod stop

重启命令:

1
service mongod restart

查看mongoDB是否启动成功:可以通过查看日志文件

1
cat /var/log/mongodb/mongod.log

日志文件应该会出现如下一句说明

1
2
[initandlisten] waiting for connections on port <port>
<port> 是mongodb运行端口

设置开机启动

1
chkconfig mongod on

使用

1
[root@instance-d0nk2r2c ~]# mongo

查看数据库

1
show dbs;

查看数据库版本

1
db.version();

常用命令帮助

1
db.help();

卸载移除mongo

1
yum erase $(rpm -qa | grep mongodb-org)

移除数据库文件和日志文件

1
2
rm -r /var/log/mongodb
rm -r /var/lib/mongo

错误解析

image

创建配置文件:
1
sudo nano /etc/systemd/system/mongodb.service
在里面追加文本:
1
2
3
4
5
6
7
8
9
10
[Unit]
Description=High-performance, schema-free document-oriented database
After=network.target

[Service]
User=mongodb
ExecStart=/usr/bin/mongod --quiet --config /etc/mongod.conf

[Install]
WantedBy=multi-user.target
按ctrl+X退出
启动服务
1
mongod -f /etc/mongod.conf &

远程访问账号密码设置

image
image

授权访问

image
image

修改vtc/mongod.conf

image

重启服务

image

远程连接

image

数据库操作

创建集合

image

插入数据

image
image

更新数据

query : update的查询条件,类似sql update查询内where后面的。
update : update的对象和一些更新的操作符(如,,inc…)等,也可以理解为sql update查询内set后面的
upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
writeConcern :可选,抛出异常的级别。
image

运行出错

1
2
以修复模式启动
/usr/bin/mongod --dbpath=/home/mongoDb/data --logpath=/home/mongoDb/log --repair