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网站地图生成类示例
Jan 13 PHP
使用PHP生成二维码的两种方法(带logo图像)
Mar 14 PHP
兼容ie6浏览器的php下载文件代码分享
Jul 14 PHP
PHP使用feof()函数读文件的方法
Nov 07 PHP
PHP连接MSSQL时nvarchar字段长度被截断为255的解决方法
Dec 25 PHP
PHP模拟登陆163邮箱发邮件及获取通讯录列表的方法
Mar 07 PHP
编写PHP脚本过滤用户上传的图片
Jul 03 PHP
Yii2框架dropDownList下拉菜单用法实例分析
Jul 18 PHP
php微信公众平台开发(四)回复功能开发
Dec 06 PHP
php常用日期时间函数实例小结
Jul 04 PHP
php实现获取近几日、月时间示例
Jul 06 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实现点击超链接执行删除确认操作
2014/10/31 PHP
php学习笔记之基础知识
2014/11/08 PHP
javascript sudoku 数独智力游戏生成代码
2010/03/27 Javascript
JS date对象的减法处理实现代码
2010/12/28 Javascript
js如何准确获取当前页面url网址信息
2020/09/13 Javascript
JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
2016/05/31 Javascript
JavaScript必知必会(十) call apply bind的用法说明
2016/06/08 Javascript
Windows系统下安装Node.js的步骤图文详解
2016/11/15 Javascript
JavaScript 程序错误Cannot use 'in' operator to search的解决方法
2017/07/10 Javascript
浅谈如何通过node.js对数据进行MD5加密
2018/05/16 Javascript
今天,小程序正式支持 SVG
2019/04/20 Javascript
vue实现跨域的方法分析
2019/05/21 Javascript
vue tab滚动到一定高度,固定在顶部,点击tab切换不同的内容操作
2020/07/22 Javascript
jQuery实现鼠标拖拽登录框移动效果
2020/09/13 jQuery
[42:36]DOTA2上海特级锦标赛B组败者赛 VG VS Spirit第二局
2016/02/26 DOTA
python解析文件示例
2014/01/23 Python
Python打包文件夹的方法小结(zip,tar,tar.gz等)
2016/09/18 Python
spark: RDD与DataFrame之间的相互转换方法
2018/06/07 Python
Pandas读取MySQL数据到DataFrame的方法
2018/07/25 Python
Python中的引用和拷贝实例解析
2019/11/14 Python
pytorch中nn.Conv1d的用法详解
2019/12/31 Python
Pycharm中切换pytorch的环境和配置的教程详解
2020/03/13 Python
keras读取h5文件load_weights、load代码操作
2020/06/12 Python
如何使用Pytorch搭建模型
2020/10/26 Python
详解Python遍历列表时删除元素的正确做法
2021/01/07 Python
html5+css3气泡组件的实现
2014/11/21 HTML / CSS
英国皇家造币厂:The Royal Mint
2018/10/05 全球购物
高中的职业生涯规划书
2013/12/28 职场文书
装饰资料员岗位职责
2013/12/30 职场文书
护士求职信
2014/07/05 职场文书
学习作风建设心得体会
2014/10/22 职场文书
2014年实习生工作总结
2014/11/27 职场文书
2015年出纳个人工作总结
2015/04/02 职场文书
《实心球》教学反思
2016/02/23 职场文书
Python基础之hashlib模块详解
2021/05/06 Python
MySQL数据管理操作示例讲解
2022/12/24 MySQL