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中在数据库中保存Checkbox数据(1)
Oct 09 PHP
PHP 表单提交给自己
Jul 24 PHP
php 无限级数据JSON格式及JS解析
Jul 17 PHP
PHP导出MySQL数据到Excel文件(fputcsv)
Jul 03 PHP
解析PHP提交后跳转
Jun 23 PHP
php生成缩略图示例代码分享(使用gd库实现)
Jan 20 PHP
php实现zip压缩文件解压缩代码分享(简单易懂)
May 10 PHP
C/S和B/S两种架构区别与优缺点分析
Oct 23 PHP
php中foreach结合curl实现多线程的方法分析
Sep 22 PHP
php面向对象的用户登录身份验证
Jun 08 PHP
PHP实现的杨辉三角求解算法分析
Mar 11 PHP
phpstudy后门rce批量利用脚本的实现
Dec 12 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 class中public,private,protected的区别以及实例分析
2013/06/18 PHP
CI框架中cookie的操作方法分析
2014/12/12 PHP
PHP设计模式之状态模式定义与用法详解
2018/04/02 PHP
PHP 结合 Boostrap 结合 js 实现学生列表删除编辑及搜索功能
2019/05/21 PHP
Mootools 1.2教程 输入过滤第一部分(数字)
2009/09/15 Javascript
基于jquery的获取mouse坐标插件的实现代码
2010/04/01 Javascript
js实现图片轮换效果代码
2013/04/16 Javascript
javaScript 计算两个日期的天数相差(示例代码)
2013/12/27 Javascript
JavaScript格式化日期时间的方法和自定义格式化函数示例
2014/04/04 Javascript
jQuery $.each遍历对象、数组用法实例
2015/04/16 Javascript
详解AngularJS中自定义指令的使用
2015/06/17 Javascript
jquery对象和DOM对象的任意相互转换
2016/02/21 Javascript
jQuery日历插件datepicker用法详解
2016/03/03 Javascript
基于zepto.js实现登录界面
2017/10/09 Javascript
three.js 利用uv和ThreeBSP制作一个快递柜功能
2020/08/18 Javascript
JS PHP字符串截取函数实现原理解析
2020/08/29 Javascript
python网络编程之数据传输UDP实例分析
2015/05/20 Python
python实现可以断点续传和并发的ftp程序
2016/09/13 Python
python内置函数:lambda、map、filter简单介绍
2017/11/16 Python
Python如何抓取天猫商品详细信息及交易记录
2018/02/23 Python
python3 cvs将数据读取为字典的方法
2018/12/22 Python
Python 正则表达式爬虫使用案例解析
2019/09/23 Python
Django中自定义查询对象的具体使用
2019/10/13 Python
python 实现让字典的value 成为列表
2019/12/16 Python
keras之权重初始化方式
2020/05/21 Python
Python自定义聚合函数merge与transform区别详解
2020/05/26 Python
Nike香港官网:Nike HK
2019/03/23 全球购物
King Apparel官网:英国街头服饰品牌
2019/09/05 全球购物
英国No.1体育用品零售商:SportsDirect.com
2019/10/16 全球购物
应届生幼儿园求职信
2013/11/12 职场文书
学校后勤人员职责
2013/12/27 职场文书
安全教育演讲稿
2014/05/09 职场文书
乡镇精神文明建设汇报材料
2014/08/15 职场文书
2015年暑期社会实践总结
2015/07/13 职场文书
十大动画制作软件,Adobe产品上榜两款,第一是行业标准软件
2022/03/18 杂记
关于vue-router-link选择样式设置
2022/04/30 Vue.js