MongoDB安装
环境:CentOS7
1.下载
2.安装
上传压缩包到服务器, 进行解压
tar -zxvf mongodb-linux-x86_64-rhel70-4.4.17.tgz
配置环境变量
vim /etc/profile
#增加MongoDB环境变量
MONGODB_HOME=/data/servers/mongodb-linux-x86_64-rhel70-4.4.17
PATH=$PATH:$MONGODB_HOME/bin
source /etc/profile
MongoDB 的数据存储在 /data 目录的 db 目录下, 日志文件默认存放/data/log
这两个目录在安装过程不会自动创建,所以需要手动创建
3.配置后台启动
创建一个启动配置文件
vim /data/servers/mongodb-linux-x86_64-rhel70-4.4.17/bin/mongodb.conf
添加一下内容
#端口, 数据路径, 日志文件,日志输出方式
port=27017
dbpath= /data/db
logpath= /data/logs/mongodb.log
logappend=true
#后台运行,最大连接数... 具体启动参数见底部启动参数详解
fork=true
maxConns=100
noauth=true
journal=true
storageEngine=wiredTiger
bind_ip = 0.0.0.0
使用配置文件启动MongoDB
mongod --config mongodb.conf 或
mongod -f mongodb.conf
或者可以把所有的启动参数加在启动命令mongod 的后面也是同样的效果
4.访问
[root@leniao167 bin]# mongo
MongoDB shell version v4.4.17
connecting to: mongodb://127.0.0.1:27017/?compressors=disabled&gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("e52db3cb-f658-42e3-8f94-dc804ff10559") }
MongoDB server version: 4.4.17
---
The server generated these startup warnings when booting:
2022-11-08T14:08:47.406+08:00: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine. See http://dochub.mongodb.org/core/prodnotes-filesystem
2022-11-08T14:08:48.448+08:00: You are running this process as the root user, which is not recommended
2022-11-08T14:08:48.448+08:00: /sys/kernel/mm/transparent_hugepage/enabled is 'always'. We suggest setting it to 'never'
2022-11-08T14:08:48.448+08:00: /sys/kernel/mm/transparent_hugepage/defrag is 'always'. We suggest setting it to 'never'
---
---
Enable MongoDB's free cloud-based monitoring service, which will then receive and display
metrics about your deployment (disk utilization, CPU, operation statistics, etc).
The monitoring data will be available on a MongoDB website with a unique URL accessible to you
and anyone you share the URL with. MongoDB may use this information to make product
improvements and to suggest MongoDB products and deployment options to you.
To enable free monitoring, run the following command: db.enableFreeMonitoring()
To permanently disable this reminder, run the following command: db.disableFreeMonitoring()
---
>
5.文件/脚本介绍
在bin文件夹下有四个脚本, 其作用分别为:
- install_compass 安装官方的可视化工具
- mongo MongoDB的交互式JavaScript Shell界面, 它提供了强大的管理界面,并为开发者提供了直接测试数据库查询和操作方法, 以及用于MongoDB的功能齐全的JavaScript环境
- mongod 是MongoDB系统的主要守护进程, 它处理数据请求, 管理数据访问并执行后台管理操作
- mongos 的实例提供客户端应用程序和分片集群之间的接口. 对于分片集群,mongos实例路由查询并将操作写入分片. 从应用程序的角度来看, mongos实例的行为与任何其他MongoDB实例相同
6. 创建mongodb服务 (未测试)
vim /etc/systemd/system/mongodb.service
[Unit]
Description=MongoDB
After=network.target
[Service]
Type=forking
WorkingDiretory=/usr/local/mongodb/mongodb-linux-x86_64-amazon-4.4.6
Environment=MONGODB_HOME=/usr/local/mongodb/mongodb-linux-x86_64-amazon-4.4.6
ExecStart=/usr/local/mongodb/mongodb-linux-x86_64-amazon-4.4.6/bin/mongod --config=/usr/local/mongodb/etc/mongodb.conf
exexStop=/usr/local/mongodb/mongodb-linux-x86_64-amazon-4.4.6/bin/mongod --shutdown -f /usr/local/mongodb/etc/mongodb.conf
PrivateTmp=true
[Install]
WantedBy=multi-user.target
Windows
C:\Program Files\MongoDB\Server\4.4\bin\mongod.exe --config "C:\Program Files\MongoDB\Server\4.4\bin\mongod.cfg" --service
mongo
mongo
> use admin;
> db.auth("josua317","password");
#查看全局所有账户
> db.system.users.find().pretty()
#查看当前库下的账户
> show users
创建超级管理员:管理所有数据库(必须use admin再去创建)
$ mongo
use admin
db.createUser(
{
user: "root",
pwd: "123456",
roles: [ { role: "root", db: "admin" } ]
}
)
db.createUser(
{
user: "haosw",
pwd: "123456",
roles: [ { role: "readWrite", db: "dbhello" } ]
}
)
MongoDB启动参数详解
--quiet # 安静输出
--port arg # 指定服务端口号,默认端口27017
--bind_ip arg # 绑定服务IP,若绑定127.0.0.1,则只能本机访问,不指定默认本地所有IP
--logpath arg # 指定MongoDB日志文件,注意是指定文件不是目录
--logappend # 使用追加的方式写日志
--pidfilepath arg # PID File 的完整路径,如果没有设置,则没有PID文件
--keyFile arg # 集群的私钥的完整路径,只对于Replica Set 架构有效
--unixSocketPrefix arg # UNIX域套接字替代目录,(默认为 /tmp)
--fork # 以守护进程的方式运行MongoDB,创建服务器进程
--auth # 启用验证
--cpu # 定期显示CPU的CPU利用率和iowait
--dbpath arg # 指定数据库路径
--diaglog arg # diaglog选项 0=off 1=W 2=R 3=both 7=W+some reads
--directoryperdb # 设置每个数据库将被保存在一个单独的目录
--journal # 启用日志选项,MongoDB的数据操作将会写入到journal文件夹的文件里
--journalOptions arg # 启用日志诊断选项
--ipv6 # 启用IPv6选项
--jsonp # 允许JSONP形式通过HTTP访问(有安全影响)
--maxConns arg # 最大同时连接数 默认2000
--noauth # 不启用验证
--nohttpinterface # 关闭http接口,默认关闭27018端口访问
--noprealloc # 禁用数据文件预分配(往往影响性能)
--noscripting # 禁用脚本引擎
--notablescan # 不允许表扫描
--nounixsocket # 禁用Unix套接字监听
--nssize arg (=16) # 设置信数据库.ns文件大小(MB)
--objcheck # 在收到客户数据,检查的有效性,
--profile arg # 档案参数 0=off 1=slow, 2=all
--quota # 限制每个数据库的文件数,设置默认为8
--quotaFiles arg # number of files allower per db, requires --quota
--rest # 开启简单的rest API
--repair # 修复所有数据库run repair on all dbs
--repairpath arg # 修复库生成的文件的目录,默认为目录名称dbpath
--slowms arg (=100) # value of slow for profile and console log
--smallfiles # 使用较小的默认文件
--syncdelay arg (=60) # 数据写入磁盘的时间秒数(0=never,不推荐)
--sysinfo # 打印一些诊断系统信息
--upgrade # 如果需要升级数据库 * Replicaton 参数
创建用户并分配权限
root管理员
db.createUser({user:"root", pwd: "123mongo", roles: ["root"]})
admin管理员
db.createUser({user:"zhangsan", pwd: "@123456", roles: ["readWrite"]})
test库
db.createUser({user:"testuser", pwd: "testuser", roles: ["readWrite"]})
ln-db-release库
db.createUser({user:"lisi", pwd: "mongo888@Uhi0", roles: ["readWrite"]})