php无法连接mongodb 3.0问题解决
1 几个常用的role
- root mongodb最高权限
- userAdmin 自己建立的数据库账号管理权限
- read 只读权限
- readWrite 可读可写
2 遭遇的梗
为数据库建立了账号,php死活连不上,使用mongo能连接上,php就是连不上
3 正确的姿势
为了安全,我们常常给web应用赋予数据库最低的权限,保证数据库安全。能只用到读的绝对不加上写
首先建立一个root role的账号
配置mongodb no auth启动之后
use admin
db.createUser({
user:'root',
pwd:'root',
roles:[
{role:'root',db:'admin'}
]})
为我们新建的数据库(test)建立一个userAdmin
use test
db.createUser({
user:'001say',
pwd:'001say',
roles:[
{role:'userAdmin',db:'test'}
]})
建立数据库连接账号
use test
db.auth('001say','001say')
db.createUser({
user:'say001',
pwd:'say001',
roles:[
{role:'read',db:'test'}
]})
这样你就获得了一个只读权限的say001账号
使用MongoClient连接的时候,可能需要以下格式
$mongo = new MongoClient("mongodb://name:password@192.168.199.140:27017/test");
需要直接在连接中指定数据库,否则MongoClient会默认去连接admin数据库。你的权限不够,当然会导致连接失败
4 后续
第二步是不可缺少的,如果你直接用root权限新建的账号,是不可以连接到test这个数据库的。
mongodb提供了很细腻的权限管理,最小权限到对集合的操作。
如果还是连不上,可能需要一个最新的驱动。pecl
如果有遇到类似问题的,希望能帮到你~~
文章纯手打,如有错误,请联系我修改~~谢谢