PHP程序员简单的开展服务治理架构操作详解(一)


Posted in PHP onMay 14, 2020

本文实例讲述了PHP程序员简单的开展服务治理架构操作。分享给大家供大家参考,具体如下:

不涉及其他的语言及工具,我们从PHP本身来谈如何实现服务治理

本猿人已经写好的服务治理 https://github.com/CrazyCodes/Service-Govern.git

治理什么?

这个专业名词很容易发现治理的是服务,而服务则是我们的项目。管理这些服务方案则叫服务治理。

现在在Server上有四项服务,分别为

  • UserService
  • ShopService
  • GoodsService
  • LiveService

这些服务我们叫它服务提供者(既提供对内服务的应用)

调用服务的应用我们称它为服务消费者,例如

  • User-Api
  • Shop-Api
  • Goods-Api
  • Live-Api

Service 是对内服务的而Api是对外服务的

PHP程序员简单的开展服务治理架构操作详解(一)

服务治理考虑的问题就是如何管理这四项服务,让它们如何对外服务,如何监控服务进程

依托实现

在实现服务治理之前,需要了解以下几块知识点

  • thrift
  • rpc
  • swoole

thrift

暂时大可理解为可以通过它去调用其他开发语言的方法

rpc

RPC(Remote Procedure Call)—远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。
RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息到达为止。当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用进程接收答复信息,获得进程结果,然后调用执行继续进行。

服务与服务之间通信可以通过RPC通信,当然也可以选择UDP等

swoole

PHP圈内跨世纪的产物,使用他的原因是因为Swoole本身支持RPC通信,所以我们本章通过Swoole Rpc的方法去实现消费者与服务提供者之间的通信

实现RPC通信

服务治理非常重要的一个环节,要在无感知的情况让消费者A调用服务提供者A,B,C,当然实际情况下,这是永远不可能的,根本不在一个内存空间中,我们需要自己模拟出来这种使用方式

$userSerivce = $client->client ('UserService');
$result = $userSerivce->getUserInfo (['user_id' => 100]);
var_dump($result);

在消费者内没有UserService,更没有getUserInfo 方法,这些都在服务提供者的应用中,如何去调用它们?

首先通过php的__call 方法去截取一个不存在的方法

public function __call($name, $arguments)
{
  $client = new ClientRpc($this->serviceName);
      
  $response = $client->send ($this->serviceName, $name, $arguments);
      
  return (json_decode ($response, true));
      
}

获取后调用自己写的send 方法,swoole出场

class ClientRpc
{
  protected $client;
    
  public function __construct($service_name, $centerConfig)
  {
    $this->client = new \swoole_client(SWOOLE_SOCK_TCP);
      
    $center = Dispatcher::loadBalance ($service_name, $centerConfig);
    $this->client->connect ($center['ip'], $center['port'], 0.5);
  }
    
  public function send($service, $action, $arguments)
  {
    $request = new Request();
    
    $request->setService ($service);
    $request->setAction ($action);
    $request->setParameters ($arguments[0]);
    // 重组参数,组合成你希望的格式,最后转成json发送到服务提供者
    $this->client->send (json_encode ((array)$request));
      
    return $this->client->recv ();
  }
    
  public function __destruct()
  {
    $this->client->close ();
    unset($this->client);
  }
}

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
拼音码表的生成
Oct 09 PHP
PHP的栏目导航程序
Oct 09 PHP
在smarty模板中使用PHP函数的方法
Apr 23 PHP
探讨PHP JSON中文乱码的解决方法详解
Jun 06 PHP
PHP分页效率终结版(推荐)
Jul 01 PHP
解析将多维数组转换为支持curl提交的一维数组格式
Jul 08 PHP
php使用pdo连接mssql server数据库实例
Dec 25 PHP
PHP实现判断数组是一维、二维或几维的方法
Feb 06 PHP
php中通过eval实现字符串格式的计算公式
Mar 18 PHP
ThinkPHP实现简单登陆功能
Apr 28 PHP
php 删除一维数组中某一个值元素的操作方法
Feb 01 PHP
laravel使用redis队列实例讲解
Mar 23 PHP
PHP程序员必须知道的两种日志实例分析
May 14 #PHP
Laravel框架集合用法实例浅析
May 14 #PHP
Laravel框架源码解析之模型Model原理与用法解析
May 14 #PHP
Laravel框架源码解析之入口文件原理分析
May 14 #PHP
Laravel框架源码解析之反射的使用详解
May 14 #PHP
PHP 数组操作详解【遍历、指针、函数等】
May 13 #PHP
ThinkPHP5 框架引入 Go AOP,PHP AOP编程项目详解
May 12 #PHP
You might like
完美实现wordpress禁止文章修订和自动保存的方法
2014/11/03 PHP
php计算数组相同值出现次数的代码(array_count_values)
2015/01/20 PHP
php与python实现的线程池多线程爬虫功能示例
2016/10/12 PHP
php实现微信支付之企业付款
2018/05/30 PHP
详解关于php的xdebug配置(编辑器vscode)
2019/01/29 PHP
php中字符串和整数比较的操作方法
2019/06/06 PHP
jQuery each()小议
2010/03/18 Javascript
jquery+json实现的搜索加分页效果
2010/03/31 Javascript
获取非最后一列td值并将title设为该值的方法
2013/10/30 Javascript
javascript修改表格背景色实例代码分享
2013/12/10 Javascript
JS 操作Array数组的方法及属性实例解析
2014/01/08 Javascript
jQuery插件easyUI实现通过JS显示Dialog的方法
2016/09/16 Javascript
jquery radio 动态控制选中失效问题的解决方法
2018/02/28 jQuery
nodejs实现范围请求的实现代码
2018/10/12 NodeJs
JS实现的合并两个有序链表算法示例
2019/02/25 Javascript
vue 解决遍历对象显示的顺序不对问题
2019/11/07 Javascript
JavaScript实现滑动门效果
2020/01/18 Javascript
vue过滤器实现日期格式化的案例分析
2020/07/02 Javascript
原生JS实现多条件筛选
2020/08/19 Javascript
Python中字符编码简介、方法及使用建议
2015/01/08 Python
python查询sqlite数据表的方法
2015/05/08 Python
Python安装Numpy和matplotlib的方法(推荐)
2017/11/02 Python
Python 类的特殊成员解析
2018/06/20 Python
selenium+python自动化测试之环境搭建
2019/01/23 Python
python中的线程threading.Thread()使用详解
2019/12/17 Python
django执行数据库查询之后实现返回的结果集转json
2020/03/31 Python
HTML5 Canvas API中drawImage()方法的使用实例
2016/03/25 HTML / CSS
微信小程序之html5 canvas绘图并保存到系统相册
2019/06/20 HTML / CSS
英国在线女鞋目的地:SIMMI
2018/12/27 全球购物
哈曼俄罗斯官方网上商店:Harman.club
2020/07/24 全球购物
初婚未育证明样本
2014/10/24 职场文书
离婚协议书怎么写
2015/01/26 职场文书
2015年财务个人工作总结范文
2015/05/22 职场文书
团队拓展训练心得体会
2016/01/12 职场文书
教师节作文之小学四年级
2019/09/03 职场文书
如何使用CocosCreator对象池
2021/04/14 Javascript