LXY3800 发表于 2018-10-26 10:19:57

centos上的mongodb的安装及php扩展mongodb

  mongodb的官网https://www.mongodb.org,可在其上下载你想要的版本。下面是我的下载、安装及启动
  下面要使用curl,如果你没有安装curl,要先安装curl
ubuntu中安装curl:  
sudo apt-get install curl libcurl3 libcurl3-dev php5-curl
curl -O -L https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.4.tgz  
tar -zxvf mongodb-linux-x86_64-3.0.4.tgz
  
cd mongodb-linux-x86_64-3.0.4
  
mkdir -p /usr/local/mongodb
  
cp -r bin /usr/local/mongodb
  
ln -s /usr/local/mongodb/bin/mongod /usr/local/sbin/mongod
  
mkdir -p /usr/local/mongodb/data
vi /usr/local/mongodb/config.conf  要编辑的内容如下
  {
  dbpath=/usr/local/mongodb/data
  logpath=/usr/local/mongodb/mongdb.log
  port=27017
  fork=true
  logappend=true
  }
mongod -f /usr/local/mongodb/config.conf //启动mongodb  让php支持mongodb
  首先可在http://pecl.php.net/package/mongo下载相应的扩展包,下面是我的安装操作
wget -c http://pecl.php.net/get/mongo-1.6.10.tgz  
tar -zxvf mongo-1.6.10.tgz
  
cd mongo-1.6.10
  
/usr/local/php/bin/phpize
  
./configure --enable-mongo=share --with-php-config=/usr/local/php/bin/php-config
  
make
  
make install
vi /etc/php.ini  在其中添加
  
  extension=mongo.so
  再重新启动php-fpm即可
  MongoDB 3.0 用户创建
  一般没有admin
  所以可以执行下面的命令
  创建admin
  mongo
  use admin
  db.createUser(
  ...   {
  ...   user: "nodebs",
  ...   pwd: "123qwe",
  ...   roles: [ { role: "dbAdmin", db: "nodebb" } ]
  ...   }
  ... )
  user:用户名
  pwd:密码
  roles:指定用户的角色,可以用一个空数组给新用户设定空角色;在roles字段,可以指定内置角色和用户定义的角色。role里的角色可以选:
  Built-In Roles(内置角色):
  1. 数据库用户角色:read、readWrite;
  2. 数据库管理角色:dbAdmin、dbOwner、userAdmin;
  3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
  4. 备份恢复角色:backup、restore;
  5. 所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
  6. 超级用户角色:root
  // 这里还有几个角色间接或直接提供了系统超级用户的访问(dbOwner 、userAdmin、userAdminAnyDatabase)
  7. 内部角色:__system
  Read:允许用户读取指定数据库
  readWrite:允许用户读写指定数据库
  dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
  userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
  clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
  readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限
  readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限
  userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
  dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
  root:只在admin数据库中可用。超级账号,超级权限
  db.createUser(
  ...{
  ...    user: "zhoujinyi",
  ...    pwd: "zhoujinyi",
  ...    roles: [
  ...       { role: "root", db: "admin" }      #超级root帐号可以对集合进行任意操作
  ...    ]
  ...}
  ... )


页: [1]
查看完整版本: centos上的mongodb的安装及php扩展mongodb