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 相关文章推荐
PHP数据缓存技术
Feb 14 PHP
java EJB 加密与解密原理的一个例子
Jan 11 PHP
php escape URL编码
Dec 10 PHP
zf框架的registry(注册表)使用示例
Mar 13 PHP
Codeigniter出现错误提示Error with CACHE directory的解决方案
Jun 12 PHP
php使用parse_url和parse_str解析URL
Feb 22 PHP
php通过curl模拟登陆DZ论坛
May 11 PHP
百度工程师讲PHP函数的实现原理及性能分析(一)
May 13 PHP
php检查页面是否被百度收录
Oct 28 PHP
twig里使用js变量的方法
Feb 05 PHP
php连接MSsql server的五种方法总结
Mar 04 PHP
laravel5使用freetds连接sql server的方法
Dec 07 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
php实现压缩合并js的方法【附demo源码下载】
2016/09/22 PHP
PHP中mysqli_get_server_version()的实例用法
2020/02/03 PHP
基于PHP实现用户在线状态检测
2020/11/10 PHP
锋利的jQuery 要点归纳(一) jQuery选择器
2010/03/21 Javascript
一些常用的JavaScript函数(json)附详细说明
2011/05/25 Javascript
js bind 函数 使用闭包保存执行上下文
2011/12/26 Javascript
jQuery队列操作方法实例
2014/06/11 Javascript
如何正确使用javascript 来进行我们的程序开发
2014/06/23 Javascript
jQuery对象的length属性用法实例
2014/12/27 Javascript
jquery 根据name名获取元素的value值
2015/02/27 Javascript
JS实现网页表格自动变大缩小的方法
2015/03/09 Javascript
Jquery常用的方法汇总
2015/09/01 Javascript
jQuery选择器及jquery案例详解(必看)
2016/05/20 Javascript
JavaScript数据类型转换的注意事项
2016/07/31 Javascript
关于react-router的几种配置方式详解
2017/07/24 Javascript
mui上拉加载更多下拉刷新数据的封装过程
2017/11/03 Javascript
基于Bootstrap表单验证功能
2017/11/17 Javascript
Vue进度条progressbar组件功能
2018/04/17 Javascript
详解为生产环境编译Angular2应用的方法
2018/12/10 Javascript
微信小程序云开发 生成带参小程序码流程
2019/05/18 Javascript
element中Steps步骤条和Tabs标签页关联的解决
2020/12/08 Javascript
npm全局环境变量配置详解
2020/12/15 Javascript
[01:03:38]2014 DOTA2国际邀请赛中国区预选赛5.21 CNB VS CIS
2014/05/22 DOTA
[47:12]TFT vs Secret Supermajor小组赛C组 BO3 第三场 6.3
2018/06/04 DOTA
在Django的视图(View)外使用Session的方法
2015/07/23 Python
用Python编写简单的微博爬虫
2016/03/04 Python
对python3 urllib包与http包的使用详解
2018/05/10 Python
python处理数据,存进hive表的方法
2018/07/04 Python
浅谈CSS3动画的回调处理
2016/07/21 HTML / CSS
世界最大的海报和艺术印刷商店:AllPosters.com
2017/02/01 全球购物
什么是符号链接,什么是硬链接?符号链接与硬链接的区别是什么?
2013/05/03 面试题
运动会广播稿80字
2014/01/23 职场文书
早读迟到检讨书
2014/01/24 职场文书
材料员岗位职责
2014/03/13 职场文书
2015年法院工作总结范文
2015/04/28 职场文书
员工辞职信范文大全
2015/05/12 职场文书