首页 > 作文

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

更新时间:2023-04-08 18:25:12 阅读: 评论:0

本文实例讲述了php程序员简单的开展服务治理架构操作。分享给大家供大家参考,具体如下:

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

上一章主要讲了下服务治理需要什么,如何实现,这章我们详细的“肢解”一下服务治理的一个非常重要的组员 thrift

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

暂时大可理解为可以通过它去调用其他开发语言的方法

本猿人已经写好的服务治理 https://github.com/crazycodes/rvice-govern

名词解释

thrift其实是一个软件框架,用来进行可扩展且跨语言的服务的开发。它结合了功能强大的软件堆栈和代码生成引擎,以构建在 c++, java, go,python, php, ruby, erlang, perl, haskell, c#, cocoa, javascript, node.js, smalltalk, and ocaml 这些编程语言间无缝结合的、高效的服务。

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

基本概念

如何调用这就需要讲一下我们强大的通信协议了。

http (tcp)

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

rpc

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

rpc的优势很多,现在你大可理解为rpc通信要比http通信快很多就是了。

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

实现方法

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

客户端

首先我们new一个client类,去调用服务端的urrivce这个类,并且调用urrvice类中的geturinfo方法。

$client = new client('urrivce');$urinfo = $client->geturinfo(1);var_dump($urinfo);

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

class client{ protected $rvicename;    public function __construct($rvicename){  $this->rvicename = $rvicename; } public function __call($name, $arguments){  $rpcclient = new \swoole_client(swoole_sock_tcp);  $rpcclient->connect('127.0.0.1',9503,0.5);  // 我们将要发送的数据是事先约定好的,跟写对外开放的api一样  $rpcclient->nd(json_encode([   'rvice'=>$this->rvicename,   'action'=>$name,   '日本经典电影params'=>$argument带字大图s[0]  ]));  $rpcclient->clo(); }}

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

服务端

$rver = new swoole_rver("127.0.0.1", 9503);$rver->on('connect', function ($rver, $fd){ echo "connection open: {$fd}\n";});$rver->on('receive', function ($rver, $fd, $reactor_id, $data) { // $data 则就是客户端发送过来的数据,我们可以这样做来做到去调用类cinderella翻译,当然你必须遵守psr-4 autoloader $request = json_decode ($data, true); $classname = $request['rvice']; $app  = new $classname; $respon = $app->{$request['action']}($request['params']);  $rver->nd($fd, "swoole: {$data}"); $rver->clo($fd);});$rver->on('clo',神舟13号什么时候发射 function ($rver, $fd) { echo "connection clo: {$fd}\n";读书的快乐});$rver->start();

往期文章

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

本文发布于:2023-04-08 18:24:10,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/724db8df6ce5bafbc719dbb1f22505a1.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:PHP程序员简单的开展服务治理架构操作详解(二).doc

本文 PDF 下载地址:PHP程序员简单的开展服务治理架构操作详解(二).pdf

下一篇:返回列表
标签:进程   服务端   信息   客户端
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图