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 相关文章推荐
echo, print, printf 和 sprintf 区别
Dec 06 PHP
AJAX for PHP简单表数据查询实例
Jan 02 PHP
PHP的分页功能
Mar 21 PHP
用PHP读取flv文件的播放时间长度
Sep 03 PHP
PHP PDO函数库详解
Apr 27 PHP
php $_SERVER["REQUEST_URI"]获取值的通用解决方法
Jun 21 PHP
PHP中使用break跳出多重循环代码实例
Jan 21 PHP
php中array_unshift()修改数组key注意事项分析
May 16 PHP
PHP基于Redis消息队列实现发布微博的方法
May 03 PHP
Laravel 5.4前后台分离,通过不同的二级域名访问方法
Oct 13 PHP
laravel 解决多库下的DB::transaction()事务失效问题
Oct 21 PHP
Thinkphp框架使用list_to_tree 实现无限级分类列出所有节点示例
Apr 04 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 日期时间函数的高级应用技巧
2009/10/10 PHP
php date与gmdate的获取日期的区别
2010/02/08 PHP
PHP中Header使用的HTTP协议及常用方法小结
2014/11/04 PHP
php中文繁体和简体相互转换的方法
2015/03/21 PHP
通过PHP的Wrapper无缝迁移原有项目到新服务的实现方法
2020/04/02 PHP
一个JavaScript继承的实现
2006/10/24 Javascript
JavaScript面向对象程序设计教程
2016/03/29 Javascript
使用jQuery实现Web页面换肤功能的要点解析
2016/05/12 Javascript
Vue开发过程中遇到的疑惑知识点总结
2017/01/20 Javascript
angularjs下拉框空白的解决办法
2017/06/20 Javascript
BootstrapTable加载按钮功能实例代码详解
2017/09/22 Javascript
详解Vue项目中出现Loading chunk {n} failed问题的解决方法
2018/09/14 Javascript
javascript中call()、apply()的区别
2019/03/21 Javascript
详解VUE前端按钮权限控制
2019/04/26 Javascript
关于layui 实现点击按钮添加一行(方法渲染创建的table)
2019/09/29 Javascript
纯JS实现五子棋游戏
2020/05/28 Javascript
[01:01:31]2018DOTA2亚洲邀请赛3月29日小组赛B组 Mineski VS paiN
2018/03/30 DOTA
[28:05]完美世界DOTA2联赛循环赛Inki vs DeMonsTer 第一场 10月30日
2020/10/31 DOTA
详细解析Python中__init__()方法的高级应用
2015/05/11 Python
简单理解Python中的装饰器
2015/07/31 Python
图文讲解选择排序算法的原理及在Python中的实现
2016/05/04 Python
Python实现带百分比的进度条
2016/06/28 Python
python检测主机的连通性并记录到文件的实例
2018/06/21 Python
python实现比较类的两个instance(对象)是否相等的方法分析
2019/06/26 Python
PyQt Qt Designer工具的布局管理详解
2019/08/07 Python
详解python itertools功能
2020/02/07 Python
python爬虫使用requests发送post请求示例详解
2020/08/05 Python
Python colormap库的安装和使用详情
2020/10/06 Python
html5 CSS过度-webkit-transition使用介绍
2013/07/02 HTML / CSS
中国第一家杂志折扣订阅网:杂志铺
2016/08/30 全球购物
解释一下抽象方法和抽象类
2016/08/27 面试题
说一下mysql, oracle等常见数据库的分页实现方案
2012/09/29 面试题
介绍一下Ruby的特点
2013/01/20 面试题
体育教育毕业生自荐信
2013/11/21 职场文书
大学教师个人总结
2015/02/10 职场文书
Java使用httpRequest+Jsoup爬取红蓝球号码
2021/07/02 Java/Android