最近有一个小 demo,需要通过 PHP 将用户行为记录储存到 MongoDB,再用 Spark 做协同过滤。由于以前处理跨语言交互是通过消息中间件,这次本地使用 MongoDB 却弄出了几个问题。首先是本地安装了扩展,启动时报找不到模块错误,再个时 PHP 进行的实例化使用时报 MongoClient 和一些函数不存在。最后也推荐一些方便快捷的 MongoDB 图形化工具。
Windows10
PHP7.4
MongoDB 4.4.14 Server
php_mongodb-1.12.1-7.4-nts-vc15-x64
1. MongoDB Server 下载
PHP 中添加扩展 php_mongodb 不正确,除了需要 php_mongodb.dll 还要 php_mongodb.pdb 复制到 php 安装目录下的 ext 中
最后在 php.ini 添加 extension=php_mongodb.dll,重启完后查看 php -m 或者浏览器中查看 phpinfo ()
原因是这个是旧版本 php_mongo 扩展提供的类,新版本是通过后面演示代码的方式,如果不知道扩展提供的新方法或函数可以通过一下方式查看。
(1). get_declared_classes () 查看扩展里预设的函数
(1). 启动服务
(1). 连接服务
public function testMongoDbQuery() { $manager = new \MongoDB\Driver\Manager("mongodb://localhost:27017"); $filter = ['x' => ['$gt' => 0]]; $options = [ 'projection' => ['_id' => 0], 'sort' => ['x' => -1], ]; // 查询数据 $query = new \MongoDB\Driver\Query($filter, $options); $cursor = $manager->executeQuery('test.sites', $query); foreach ($cursor as $document) { print_r($document); } }
public function testMongoDbInsert() { $manager = new \MongoDB\Driver\Manager("mongodb://localhost:27017"); $bulk = new \MongoDB\Driver\BulkWrite; // mongoDb默认存在一个自增长的字符串ID $document = [ '_id' => new \MongoDB\BSON\ObjectID, 'videoId' => mt_rand(1, 99999), 'userId' => mt_rand(1, 9999), 'score' => floatval(mt_rand(5,100)), 'date' => time() ]; $bulk->insert($document); $res = $manager->executeBulkWrite('tanhua.recommend_video_20191001', $bulk); return $res; }
public function testMongoDbBulk() { //return get_declared_classes(); $manager = new \MongoDB\Driver\Manager("mongodb://localhost:27017"); $bulk = new \MongoDB\Driver\BulkWrite; $bulk->insert(['x' => 1, 'name'=>'tenent', 'url' => 'http://www.runoob.com']); $bulk->insert(['x' => 2, 'name'=>'Google', 'url' => 'http://www.google.com']); $bulk->insert(['x' => 3, 'name'=>'taobao', 'url' => 'http://www.taobao.com']); $res = $manager->executeBulkWrite('test.sites', $bulk); return $res; }