不涉及其余的语言及工具,咱们从PHP自己来谈如何实现服务治理php
本猿人已经写好的服务治理 https://github.com/CrazyCodes...
这个专业名词很容易发现治理的是服务,而服务则是咱们的项目。管理这些服务方案则叫服务治理。git
如今在Server上有四项服务,分别为github
这些服务咱们叫它服务提供者(既提供对内服务的应用)json
调用服务的应用咱们称它为服务消费者,例如服务器
Service 是对内服务的而Api是对外服务的swoole
图片来源 http://blog.csdn.net/suifeng3...网络
服务治理考虑的问题就是如何管理这四项服务,让它们如何对外服务,如何监控服务进程分布式
在实现服务治理以前,须要了解如下几块知识点工具
暂时大可理解为能够经过它去调用其余开发语言的方法ui
RPC(Remote Procedure Call)—远程过程调用,它是一种经过网络从远程计算机程序上请求服务,而不须要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通讯程序之间携带信息数据。在OSI网络通讯模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。
RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,而后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息到达为止。当一个调用信息到达,服务器得到进程参数,计算结果,发送答复信息,而后等待下一个调用信息,最后,客户端调用进程接收答复信息,得到进程结果,而后调用执行继续进行。
服务与服务之间通讯能够经过RPC通讯,固然也能够选择UDP等
PHP圈内跨世纪的产物,使用他的缘由是由于Swoole自己支持RPC通讯,因此咱们本章经过Swoole 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); } }
周梦康 [https://mengkang.net/]