arden / nats
PHP中的nats.io客户端
0.8.8
2019-07-23 11:44 UTC
Requires
- ircmaxell/random-lib: ^1.2
Requires (Dev)
- leanphp/phpspec-code-coverage: ^3.2@dev
- phpspec/phpspec: ^3.0
- phpunit/phpunit: 5.*
- satooshi/php-coveralls: 2.0.x-dev
README
Travis
覆盖率
简介
PHP的NATS消息系统客户端。
需求
- php 5.6+
- gnatsd
使用方法
安装
让我们首先将composer下载到我们的项目目录中
curl -O https://composer.php.ac.cn/composer.phar
chmod +x composer.phar
现在让我们告诉composer我们的项目依赖项,在本例中是PHPNats。我们这样做是通过创建一个composer.json文件,并将其放置在我们的项目的根目录中,紧挨着composer.phar
{
"require": {
"repejota/nats": "dev-master"
}
}
让我们让Composer施展魔法
php composer.phar install
Composer将下载composer.json中定义的所有依赖项,并准备所有需要自动加载的文件。
基本用法
$client = new \Nats\Connection(); $client->connect(); // Publish Subscribe // Simple Subscriber. $client->subscribe( 'foo', function ($message) { printf("Data: %s\r\n", $message->getBody()); } ); // Simple Publisher. $client->publish('foo', 'Marty McFly'); // Wait for 1 message. $client->wait(1); // Request Response // Responding to requests. $sid = $client->subscribe( 'sayhello', function ($message) { $message->reply('Reply: Hello, '.$message->getBody().' !!!'); } ); // Request. $client->request( 'sayhello', 'Marty McFly', function ($message) { echo $message->getBody(); } );
编码连接
$encoder = new \Nats\Encoders\JSONEncoder(); $options = new \Nats\ConnectionOptions(); $client = new \Nats\EncodedConnection($options, $encoder); $client->connect(); // Publish Subscribe // Simple Subscriber. $client->subscribe( 'foo', function ($payload) { printf("Data: %s\r\n", $payload->getBody()[1]); } ); // Simple Publisher. $client->publish( 'foo', [ 'Marty', 'McFly', ] ); // Wait for 1 message. $client->wait(1); // Request Response // Responding to requests. $sid = $client->subscribe( 'sayhello', function ($message) { $message->reply('Reply: Hello, '.$message->getBody()[1].' !!!'); } ); // Request. $client->request( 'sayhello', [ 'Marty', 'McFly', ], function ($message) { echo $message->getBody(); } );
开发者信息
发布版本
测试
测试在tests目录中。要运行它们,您需要PHPUnit并执行make test-tdd。
我们还在spec目录下有一个BDD测试套件。要运行套件,您需要PHPSpec并执行make test-bdd。
您也可以使用make test执行所有套件(TDD + BDD)。
代码质量
我们使用PHP Code Sniffer来确保我们的代码遵循高标准。
要执行代码分析,请执行make lint。
当我们在代码上执行lint时,目前有三个步骤
- 首先,我们使用php本身进行lint
php -l - 然后,我们使用PSR2标准进行lint
- 最后,我们使用一个自定义的ruleset.xml进行lint,该文件检查docblocks和不同的性能提示。
创建者
Raül Pérez
许可协议
MIT,见LICENSE