根据 homebrew-brew 官方的解释得知,MongoDB 不再是开源的了,并且已经从 Homebrew中移除 #43770
正是由于 MongoDB 的商业化不太理想,所以它选择了闭源。所以,在它闭源之前的那些 brew 安装方法都会报错了。网上很多的文章都是基于以前古老的安装方式,这种方式导致 brew 无法安装,报错。
1
|
Error: No available formula with the name ‘mongodb' |
新的安装方式可以参考 github 主页,https://github.com/mongodb/homebrew-brew。
新的安装方式告诉我们,需要先执行:
1
|
brew tap mongodb /brew |
接着在执行:
1
|
brew install mongodb-community |
这是安装的社区版的。如果需要安装指定版本的,可以带上 @版本号。
1
2
3
4
5
|
brew install mongodb-community@4.2 brew install mongodb-community@4.0 brew install mongodb-community@3.6 |
如果仅想安装最新的 mongoshell,则可以执行下面的命令。
1
|
brew install mongodb-community-shell |
如果出现 Download failed 或 DownloadError: Failed to download resource “mongodb-community” 错误,则重复执行安装命令,进行下载。这属于你的网络问题,多尝试几次。
安装后的默认配置文件路径如下:
1
2
3
4
5
|
#配置文件:/usr/local/etc/mongod.conf #日志目录路径:/usr/local/var/log/mongodb #数据目录路径:/usr/local/var/mongodb |
有了 brew 后,启动 Mongo 和停止 Mongo 就很方便了。
1
2
3
4
5
6
7
8
9
10
11
|
#启动 brew services start mongodb-community #或 brew services start mongodb /brew/mongodb-community #停止 brew services stop mongodb-community #或 brew services stop mongodb /brew/mongodb-community |
安装好了之后,我们需要做一些配置,不能让 mongo 裸奔,这些年出了不少泄露数据的事故,我们得配置一下安全认证。
首先,我们启动 mongo 成功后,执行下面的命令:
1
2
3
4
5
6
7
8
9
10
11
12
|
#链接 mongo mongo #切换db,或创建 xttblog use xttblog #创建用户admin db.createUser({ user: 'admin' , pwd : 'admin' , roles:[{role: 'readWrite' ,db: 'xttblog' }] }) |
如果创建成功,则提示:Successfully added user。
1
2
3
4
5
6
7
8
9
|
Successfully added user: { "user" : "admin" , "roles" : [ { "role" : "readWrite" , "db" : "xttblog" } ] } |
角色设置需要注意,userAdminAnyDatabase 之类的默认没有了,可以通过 show roles 命令查看角色。
1
2
3
4
5
|
#查看角色 show roles #查看用户 show users |
如果要修改用户角色,则可以执行 db.updateUser 命令。
1
2
3
4
5
6
7
8
9
10
|
db.updateUser( "admin" , { roles:[ {role: "readWrite" ,db: "xttblog" }, {role: "userAdmin" ,db: "xttblog" }, {role: "dbAdmin" ,db: "xttblog" } ] } ) |
操作完成后,我们就可以修改 mongo 的配置文件了,开启认证。
1
|
vi /usr/local/etc/mongod .conf |
在文件最后加入:“#开启权限校验”之后的配置。
1
2
3
4
5
6
7
8
9
10
11
12
|
systemLog: destination: file path: /usr/local/var/log/mongodb/mongo .log logAppend: true storage: dbPath: /usr/local/var/mongodb net: bindIp: 127.0.0.1 port: 27017 # 开启权限校验 security: authorization: enabled |
重启服务。再次操作 mongo 就需要进行认证了。
1
2
3
|
mongo use xttblog db.auth( "xttblog" , "xttblog" ) |
同样的 SpringBoot 整合 Mongo 的 url 就得配置上密码认证了。
1
|
mongodb: //admin :admin@localhost:27017 /xttblog |
至此MongoDB安装完成,更多关于安装 mongodb 报错的问题请查看下面的相关链接
原文链接:https://www.xttblog.com/?p=4609