当前位置:首页 > PHP教程 > php高级应用 > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2022-03-06 13:12:00 浏览: 评论:0 

本文实例讲述了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,当然实际情况下,这是永远不可能的,根本不在一个内存空间中,我们需要自己模拟出来这种使用方式。

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

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

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

  1. public function __call($name$arguments
  2.   $client = new ClientRpc($this->serviceName); 
  3.         
  4.   $response = $client->send ($this->serviceName, $name$arguments); 
  5.         
  6.   return (json_decode ($response, true)); 
  7.         

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

  1. class ClientRpc 
  2.   protected $client
  3.       
  4.   public function __construct($service_name$centerConfig
  5.   { 
  6.     $this->client = new \swoole_client(SWOOLE_SOCK_TCP); 
  7.         
  8.     $center = Dispatcher::loadBalance ($service_name$centerConfig); 
  9.     $this->client->connect ($center['ip'], $center['port'], 0.5); 
  10.   } 
  11.       
  12.   public function send($service$action$arguments
  13.   { 
  14.     $request = new Request(); 
  15.       
  16.     $request->setService ($service); 
  17.     $request->setAction ($action); 
  18.     $request->setParameters ($arguments[0]); 
  19.     // 重组参数,组合成你希望的格式,最后转成json发送到服务提供者 
  20.     $this->client->send (json_encode ((array)$request)); 
  21.         
  22.     return $this->client->recv (); 
  23.   } 
  24.       
  25.   public function __destruct() 
  26.   { 
  27.     $this->client->close (); 
  28.     unset($this->client); 
  29.   } 
  30. }

Tags: PHP服务治理架构

分享到: