yurunsoft / guzzle-swoole
让 Guzzle 支持 Swoole 协程,可以用于 ElasticSearch、AWS 等 SDK 当中
Installs: 100 251
Dependents: 9
Suggesters: 0
Security: 0
Stars: 161
Watchers: 5
Forks: 21
Open Issues: 2
Type:composer-plugin
Requires
- php: >=7.1
- composer-plugin-api: ^1.0|^2.0
- guzzlehttp/guzzle: ~6.0|~7.0
- guzzlehttp/ringphp: ~1.0
- yurunsoft/composer-include-files: ^1.0|^2.0
- yurunsoft/yurun-http: ^4.0
Requires (Dev)
- composer/composer: ^1.0|^2.0
- phpunit/phpunit: >=7
- swoole/ide-helper: *
README
介绍
guzzle-swoole 可以无损支持 Guzzle 在 Swoole 协程环境下的运行,不需要修改任何一行第三方包代码,即可支持协程化。
支持 Guzzle v6.x、v7.x。
支持 Composer v1.x、v2.x。
可以用于 ElasticSearch
、AWS
等 SDK 当中。
兼容所有 Swoole 框架。
使用说明
安装
手动改 composer.json
:"yurunsoft/guzzle-swoole":"^2.2"
命令行安装:composer require yurunsoft/guzzle-swoole
全局设定处理器
<?php require dirname(__DIR__) . '/vendor/autoload.php'; use GuzzleHttp\Client; use Yurun\Util\Swoole\Guzzle\SwooleHandler; use GuzzleHttp\DefaultHandler; // 在你的项目入口加上这句话 DefaultHandler::setDefaultHandler(SwooleHandler::class); go(function(){ $client = new Client(); $response = $client->request('GET', 'http://www.baidu.com', [ 'verify' => false, ]); var_dump($response->getStatusCode()); });
手动指定 Swoole 处理器
use GuzzleHttp\Client; use GuzzleHttp\HandlerStack; use Yurun\Util\Swoole\Guzzle\SwooleHandler; go(function(){ $handler = new SwooleHandler(); $stack = HandlerStack::create($handler); $client = new Client(['handler' => $stack]); $response = $client->request('GET', 'http://www.baidu.com', [ 'verify' => false, ]); var_dump($response->getBody()->__toString(), $response->getHeaders()); });
更加详细的示例代码请看test
目录下代码。
ElasticSearch
$client = \Elasticsearch\ClientBuilder::create()->setHosts(['192.168.0.233:9200'])->setHandler(new \Yurun\Util\Swoole\Guzzle\Ring\SwooleHandler())->build();