控制器聚合调用

  1. namespace App\HttpController;
  2. use EasySwoole\Http\AbstractInterface\Controller;
  3. use EasySwoole\Rpc\Response;
  4. use EasySwoole\Rpc\Rpc;
  5. class Index extends Controller
  6. {
  7. function index()
  8. {
  9. $ret = [];
  10. $client = Rpc::getInstance()->client();
  11. /*
  12. * 调用商品列表
  13. */
  14. $client->addCall('goods','list',['page'=>1])
  15. ->setOnSuccess(function (Response $response)use(&$ret){
  16. $ret['goods'] = $response->toArray();
  17. })->setOnFail(function (Response $response)use(&$ret){
  18. $ret['goods'] = $response->toArray();
  19. });
  20. /*
  21. * 调用信箱公共
  22. */
  23. $client->addCall('common','mailBox')
  24. ->setOnSuccess(function (Response $response)use(&$ret){
  25. $ret['mailBox'] = $response->toArray();
  26. })->setOnFail(function (Response $response)use(&$ret){
  27. $ret['mailBox'] = $response->toArray();
  28. });
  29. /*
  30. * 获取系统时间
  31. */
  32. $client->addCall('common','serverTime')
  33. ->setOnSuccess(function (Response $response)use(&$ret){
  34. $ret['serverTime'] = $response->toArray();
  35. });
  36. $client->exec(2.0);
  37. $this->writeJson(200,$ret);
  38. }
  39. }

注意,控制器中可以这样调用,是因为服务端章节中,在EasySwoole的全局启动事件已经对当前的Rpc实例定义注册了节点管理器。因此在控制器中调用的时候 该Rpc实例可以找到对应的节点。一般来说,在做聚合网关的节点,是不需要注册服务进去的,仅需注册节点管理器即可。