maslosoft/mongofill

PECL Mongo 扩展的 Polyfill

0.0.3 2016-03-09 14:12 UTC

This package is auto-updated.

Last update: 2024-08-26 04:59:48 UTC


README

MongoDB 驱动的纯 PHP 实现,旨在作为官方扩展的替代品,适用于 HHVM 运行时。

安装

推荐方法

推荐的安装方法是使用 mongofill-hhvm 包作为 HHVM 的 HNI 扩展。

git clone https://github.com/mongofill/mongofill-hhvm
cd mongofill-hhvm
./build.sh

您可以在 HNI 包的 构建和安装说明 中查看完整说明。

简单方法

安装 Mongofill 的简单方法是使用 composer。您可以在 Packagist 上查看 包信息

{
    "require": {
        "mongofill/mongofill": "dev-master"
    }
}

注意:作为纯 PHP,phpversion('mongo') 将返回 null,并且某些库(如 Doctrine)将无法正常工作 而不进行修改,因此请使用 HNI 版本。

支持的库

您可以在 支持的库 维基页面查看当前支持的库。

社区

您可以在 Freenode 上的 #mongofill 频道找到我们。

贡献

请将测试推送到 "compat/not-passing" 分支,确保与官方 Mongo 扩展的兼容性。

贡献非常受欢迎,包括对我们的英文进行校正 ;)

为确保代码库一致,请确保代码遵循 PSR2 编码标准。我们建议在提交 pull request 之前使用 php-cs-fixer 对您的代码进行处理:php-cs-fixer fix . --level=all

运行 PHPUnit 测试

测试位于 test 文件夹中。要运行它们,您需要 PHPUnit。

phpunit --configuration phpunit.xml.dist

运行 native mongo-php-driver 测试

您可以在 test/native/helper.sh 中找到辅助脚本。您的系统必须已安装:mongodb、git、phpize 和 autotools。

cd tests/native/
./helper.sh setup
./helper.sh boot
./helper.sh run

基准测试

该软件包包含一组基准测试,您可以使用此命令运行该组:...

php ./vendor/bin/athletic -b tests/bootstrap.php  -p tests/Mongofill/Benchmarks/

一些结果可以在:https://gist.github.com/mcuadros/9551290

注意事项

副本集 & APC

当使用副本集时,Mongofill 驱动程序需要获取有关副本集配置和状态的信息。为了提高性能,驱动程序将尝试使用 APC(apc_fetch、apc_store)来缓存副本集数据。

APC 函数应该与 HHVM 自动安装,但如果您计划使用 PHP 与 Mongofill 驱动程序一起使用,则请确保您已安装 APC 以获得性能提升。

对于 PHP 5.5 及更高版本,这将是一个 APCu 扩展。如果未安装 APC,副本集仍然可以工作,但它们的速度将不如以前快。