PHP程序员如何简单的开展服务治理架构(二)

服务治理 治理的绝笔是服务,在一家公司有玩各类语言的程序员,如何去统一管理他们开发的服务,这是一个问题。php

上一章主要讲了下服务治理须要什么,如何实现,这章咱们详细的“肢解”一下服务治理的一个很是重要的组员 Thriftreact

上一章说明他的时候是这样写的git

暂时大可理解为能够经过它去调用其余开发语言的方法
本猿人已经写好的服务治理 https://github.com/CrazyCodes...

名词解释

thrift实际上是一个软件框架,用来进行可扩展且跨语言的服务的开发。它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Go,Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml 这些编程语言间无缝结合的、高效的服务。程序员

这个时候你就疑惑了?,如何跨语言调用github

基本概念

如何调用这就须要讲一下咱们强大的通讯协议了。apache

http (tcp)

超文本传输协议,正常访问浏览器啥看新闻、购物的时候一定使用,须要客户端和服务端握手?成功才能够正常显示,这中间握手的流出很复杂,执行各类各样的解码编码(为了方便理解,暂时这么想吧)编程

rpc

远程过程调用协议,RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供者就是一个服务器。首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,而后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息到达为止。当一个调用信息到达,服务器得到进程参数,计算结果,发送答复信息,而后等待下一个调用信息,最后,客户端调用进程接收答复信息,得到进程结果,而后调用执行继续进行。

rpc的优点不少,如今你大可理解为rpc通讯要比http通讯快不少就是了。json

这个时候facebook和apache就厉害了,它们基于rpc通讯协议开发出了一套thriftsegmentfault

实现方法

  • 上面假设你都没看懂,这里咱们实战下。
  • 首先rpc咱们经过使用swoole来实现,其余的手码。
  • 分为客户端和服务端作下演示

客户端

首先咱们new一个client类,去调用服务端的UserSerivce这个类,而且调用UserService类中的getUserInfo方法。浏览器

$client = new Client('UserSerivce');
$userInfo = $client->getUserInfo(1);

var_dump($userInfo);

Client中咱们只须要干这样的一件事,使用php魔术方法__call去调用一个不存在的方法

class Client{
    protected $serviceName;
            
    public function __construct($serviceName){
        $this->serviceName = $serviceName;
    }
    public function __call($name, $arguments){
        $rpcClient = new \swoole_client(SWOOLE_SOCK_TCP);
        $rpcClient->connect('127.0.0.1',9503,0.5);
        // 咱们将要发送的数据是事先约定好的,跟写对外开放的Api同样
        $rpcClient->send(json_encode([
            'service'=>$this->serviceName,
            'action'=>$name,
            'params'=>$arguments[0]
        ]));
        $rpcClient->close();
    }
}

这个时候数据就经过rpc协议以json格式发送到了服务端

服务端

$server = new swoole_server("127.0.0.1", 9503);
$server->on('connect', function ($server, $fd){
    echo "connection open: {$fd}\n";
});
$server->on('receive', function ($server, $fd, $reactor_id, $data) {
    // $data 则就是客户端发送过来的数据,咱们能够这样作来作到去调用类,固然你必须遵照PSR-4 Autoloader
    $request   = json_decode ($data, true);
    $className = $request['service'];
    $app       = new $className;
    $response  = $app->{$request['action']}($request['params']);
    
    $server->send($fd, "Swoole: {$data}");
    $server->close($fd);
});
$server->on('close', function ($server, $fd) {
    echo "connection close: {$fd}\n";
});
$server->start();

往期文章

鸣谢

周梦康 https://mengkang.net/

相关文章
相关标签/搜索