maslosoft / mongofill
PECL Mongo 扩展的 Polyfill
Requires (Dev)
- athletic/athletic: dev-master
- phpunit/phpunit: ~4.7.7
Provides
- ext-mongo: *
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,副本集仍然可以工作,但它们的速度将不如以前快。