Hyperf-JsonRpc使用

标签(空格分隔): php

安装扩展包

composer require hyperf/json-rpc
composer require hyperf/rpc-server
composer require hyperf/rpc-client

使用

服务有两种角色,一种是 服务提供者(ServiceProvider),即为其它服务提供服务的服务,另一种是 服务消费者(ServiceConsumer),即依赖其它服务的服务,一个服务既可能是 服务提供者(ServiceProvider),同时又是 服务消费者(ServiceConsumer)。而两者直接可以通过 服务契约 来定义和约束接口的调用,在 Hyperf 里,可直接理解为就是一个 接口类(Interface),通常来说这个接口类会同时出现在提供者和消费者下。

server.php

servers 下增加配置

        // jsonrpc-http 服务配置
[
'name' => 'jsonrpc-http',
'type' => Server::SERVER_HTTP,
'host' => '0.0.0.0',
'port' => 9504,
'sock_type' => SWOOLE_SOCK_TCP,
'callbacks' => [
Event::ON_REQUEST => [\Hyperf\JsonRpc\HttpServer::class, 'onRequest'],
],
],

services.php 标记要从何服务中心或者哪个节点 获取节点信息,服务中心配起来很麻烦

<?php
return [
'consumers' => [
[
// 对应消费者类的 $serviceName
'name' => 'UserServiceServer',
// 这个消费者要从哪个服务中心获取节点信息,如不配置则不会从服务中心获取节点信息
// 'registry' => [
// 'protocol' => 'consul',
// 'address' => 'http://127.0.0.1:8500',
// ],
// 如果没有指定上面的 registry 配置,即为直接对指定的节点进行消费,通过下面的 nodes 参数来配置服务提供者的节点信息
'nodes' => [
['host' => '127.0.0.1', 'port' => 9504],
],
]
],
];

目录结构

定义Server端来提供服务

// 定义接口,更加规范
<?php
declare(strict_types=1); namespace App\Rpc\Inter; interface UserServiceInter
{
public function getUserInfo(int $userId) : string; public function getUserList(int $page, int $pageSize, array $params = []) : string;
} // server
<?php
declare(strict_types=1); namespace App\Rpc\Server; use App\Rpc\Inter\UserServiceInter;
use App\Utils\ResJson;
use Hyperf\Di\Annotation\Inject;
use Hyperf\RpcServer\Annotation\RpcService; /**
* Rpc用户服务
* Class RpcUserService
* @package App\Rpc
* name: 服务名称全局唯一
* protocol: 服务协议:jsonrpc-http, jsonrpc, jsonrpc-tcp-length-check
* @RpcService(name="UserServiceServer", protocol="jsonrpc-http", server="jsonrpc-http", publishTo="consul")
*/
class UserServiceServer implements UserServiceInter
{ /**
* @Inject()
* @var ResJson
*/
public $resJson; /**
* 获取用户信息
* @param int $userId
* @return string
*/
public function getUserInfo(int $userId) : string
{
$array['user_id'] = $userId;
$array['user_name'] = "PHP";
return $this->resJson->returnJsonString(ResJson::CODE_200, $array);
} /**
* 获取用户列表
* @param int $page 页码数
* @param int $pageSize 每页条数
* @param array $params 可选参数
* @return string
*/
public function getUserList(int $page, int $pageSize, array $params = []): string
{
$user[] = ['user_id' => 1, 'user_name' => 'Bill'];
$user[] = ['user_id' => 2, 'user_name' => 'Taylor'];
$user[] = ['user_id' => 3, 'user_name' => 'Jerry'];
return $this->resJson->returnJsonString(ResJson::CODE_200, $user);
}
}

定义服务消费者

<?php
declare(strict_types=1); namespace App\Rpc\Client; use App\Rpc\Inter\UserServiceInter;
use Hyperf\RpcClient\AbstractServiceClient; class UserServiceClient extends AbstractServiceClient implements UserServiceInter
{
/**
* 服务提供者的服务名称
* @var string
*/
protected $serviceName = "UserServiceServer"; /**
* 定义对应服务提供者的服务协议
* @var string
*/
protected $protocol = 'jsonrpc-http'; public function getUserInfo(int $userId) : string
{
return $this->__request(__FUNCTION__, compact('userId'));
} public function getUserList(int $page, int $pageSize, array $params = []): string
{
return $this->__request(__FUNCTION__, compact('page', 'pageSize', 'params'));
}
}

使用Rpc服务

在config/autoload/dependencies.php 内定义 UserServiceInter 和 UserServiceClient 的关系

// 这样便可以通过注入 UserServiceInter 接口来使用客户端了
\App\Rpc\Inter\UserServiceInter::class => \App\Rpc\Client\UserServiceClient::class,

这样便可以通过注入 UserServiceInter 接口来使用客户端了。

Controller 代码:

<?php

declare(strict_types=1);

namespace App\Admin\Controller;

use App\Admin\Model\UserModel;
use App\Admin\Service\UserService;
use App\Event\AppException;
use App\Rpc\Inter\UserServiceInter;
use Hyperf\DbConnection\Db;
use Hyperf\Di\Annotation\Inject;
use Hyperf\HttpServer\Annotation\AutoController;
use Hyperf\Utils\Context;
use Psr\EventDispatcher\EventDispatcherInterface;
use function _HumbugBoxa5be08ba8ddb\React\Promise\Stream\first; /**
* 用户控制器
* Class UserController
* @package App\Admin\Controller
* @AutoController()
*/
class UserController extends AdminBaseController
{
/**
* @Inject()
* @var UserServiceInter
*/
public $rpcUserService; public function rpc()
{
$arr = $this->rpcUserService->getUserInfo(919);
var_dump($arr);
return $arr;
} public function rpcuserlist()
{
$arr = $this->rpcUserService->getUserList(1, 10);
var_dump($arr);
return $arr;
}
}

重启hyperf 运行

Hyperf-JsonRpc使用的更多相关文章

  1. hyperf从零开始构建微服务(一)——构建服务提供者

    阅读目录 什么是服务 构建服务提供者 1.创建数据表 2.构建服务提供者 3.安装json rpc依赖 4.安装rpc server组件 5.修改server配置 6.配置数据库 7.编写基础代码 7 ...

  2. hyperf从零开始构建微服务(二)——构建服务消费者

    阅读目录 构建服务消费者 安装json rpc依赖 安装JSON RPC客户端 server配置 编写业务代码 编写服务消费者类 consumer配置 配置 UserServiceInterface ...

  3. NodeJS POST Request Over JSON-RPC

    1.npm install art-template2.npm  install request3.在app.js中加入以下代码转html: var template = require('art-t ...

  4. 使用Jayrock开源组件开发基于JSON-RPC协议的接口

    最近接手一个以前的项目,无意间发现此项目开发接口的组件:Jayrock(接口组件估计用的少,用的最多的估计是这个Jayrock.json.dll,用于解析json) 以下是Jayrock的介绍官网: ...

  5. Lua JSONRPC学习笔记

    JSON RPC JSON RPC 为利用json数据格式来执行远程调用方式, 作用同xmlrpc,不过与xmlrpc相比, jsonrpc更加轻量,json更加节省数据量,更加可读性高. 官网网站: ...

  6. JSON-RPC轻量级远程调用协议介绍及使用

    这个项目能够帮助开发人员利用Java编程语言轻松实现JSON-RPC远程调用.jsonrpc4j使用Jackson类库实现Java对象与JSON对象之间的相互转换.jsonrpc4j包含一个JSON- ...

  7. PHPCURL直接访问JSONRPC服务

    <?php $ch = curl_init(); $url = 'http://localhost/jsonrpc?tm='.time().mt_rand (100,999); //参数是为了防 ...

  8. 利用QObject反射实现jsonrpc

    1.jsonrpc请求中的params数组生成签名 static QString signatureFromJsonArray(const QJsonArray &array) { QStri ...

  9. A simple json-rpc case for bitcoin blockchains

    #!/usr/bin/env python import json import jsonrpc import requests #url = "http://user:password@i ...

随机推荐

  1. 设计模式(二)——Java简单工厂模式

    简单工厂模式 案例: 披萨的项目(要便于披萨种类的扩展,要便于维护) 1)披萨的种类很多(比如 GreekPizz.CheesePizz 等) 2)披萨的制作有 prepare,bake, cut, ...

  2. Nestjs 路程 之 异常过滤器Exceptionfilter

    参考文档:docs.nestjs.cn 说起Nestjs的异常过滤器,不能不提.Net的全局过滤器Filter,功能那是相当的强悍,用理论话说叫AOP 面向切面编程,可谓方便了太多需要异常处理的场景. ...

  3. AtCoder Beginner Contest 173

    比赛链接:https://atcoder.jp/contests/abc173/tasks A - Payment 题意 计算只用 $1000$ 元支付某个价格 $n$ 的找零是多少. 代码 #inc ...

  4. 【bzoj 2597】[Wc2007]剪刀石头布(图论--网络流 最小费用最大流)

    题目:在一些一对一游戏的比赛(如下棋.乒乓球和羽毛球的单打)中,我们经常会遇到A胜过B,B胜过C而C又胜过A的有趣情况,不妨形象的称之为剪刀石头布情况.有的时候,无聊的人们会津津乐道于统计有多少这样的 ...

  5. ZOJ3640-Help Me Escape 概率dp

    题意: 在一个迷宫中有n条路经,你会被随机传送到一条路径,每条路径有一个挑战难度ci,你最初有一个战斗力f,如果你的战斗力大于ci,那么呆在那里ti天就可以成功逃出迷宫.如果你的战斗力小于等于ci,那 ...

  6. 2019牛客暑期多校训练营(第四场)k题、j题

    传送门 k题: 题意: 给你一串由数字构成的字符串,你从这个字符串中找子字符串使这个字符串是300的倍数 题解: 这道题和第三场的B题极其相似 首先可以把是三百的倍数分开,必须要是100和3的倍数 是 ...

  7. js--执行上下文和作用域相关问题

    前言 如果你是或者你想成为一名合格的前端开发工作者,你必须知道JavaScript代码在执行过程,知道执行上下文.作用域.变量提升等相关概念,并且熟练应用到自己的代码中.本文参考了你不知道的JavaS ...

  8. 3.PowerShell DSC核心概念

    PowerShell DSC有三个核心概念 配置 配置是声明性的PowerShell 脚本,用于定义和配置资源实例. DSC 配置是幂等的. 资源 资源是 DSC 的"实现器"部分 ...

  9. 洛谷 P4143 采集矿石 后缀数组

    题目背景 ZRQ 成功从坍塌的洞穴中逃了出来.终于,他看到了要研究的矿石.他想挑一些带回去完成任务. 题目来源:Zhang_RQ哦对了 \(ZRQ\) 就他,嗯 题目描述 ZRQ 发现这里有 \(N\ ...

  10. Failed to start LSB 网络服务启动失败

    有些时候 VMare虚拟机挂起,重新运行后,XShell远程连接不上,检查VMare虚拟机,重启网卡会报错,查看日志,会有 Failed to start LSB .... CentOS7 会有一个网 ...