Guzzle-Swoole 让基于 Guzzle 的项目完美无缝兼容 Swoole 协程
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();
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论