首页 > 作文

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

更新时间:2023-04-08 18:58:37 阅读: 评论:0

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

不涉及其他的语言及工具,我们从php本身来谈如何实现服务治理

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

治理什么?

这梦见别人请吃饭个专业名词很容易发现治理的是服务,而服务则是我们的项目。管理这些服务方案则叫服务治理。

现在在rver上有四项服务,分别为

urrviceshoprvicegoodsrviceliv掣肘难书ervice

这些服务我们叫它服务提供者(既提供对内服务的应用)

调用服务的应用我们称它为服务消费者,例如

ur-apishop-apigoods-apilive-api

rvice 是对内服务的而api是对外服务的

服务治理考虑的问题就是如何管理这四项服务,让它们如何对外服务,如何监控服务进程

依托实现

在实现服务治理之前,需要了解以下几块知识点

thriftrpcswoole

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

$urrivce = $client->client ('urrvice');$result = $urrivce->geturinfo (['ur_id' => 100]);var_dump($result);

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

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

public function __call($name, $arguments){  $client = new clientrpc($this->rvicename);        $respon = $client->nd ($this->s霸气的歌ervicename, $name, $arguments);        return (json_decode ($respon, true));      }

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

class clientrpc{  protected $client;      public陕西省的大学 function __construct($rvice_name, $centerconfig)  {    $this->client = new \swoole_client(swoole_sock_tcp);          $center = dispatcher::loadbalance ($rvice_name, $centerconfig);    $this->client->connect ($center['ip'], $center['port'], 0.5);  }      public function nd($rvice, $action, $arguments)  {    $request = new request();        $request->trvice ($rvice);    $request->taction ($action);    $request->tparameters ($arguments[0]);    // 重组参数,组合成你希望的格式,最后转成json发送到服务提供者    $this->client->nd (json_encode ((array)$request));          return $this->client->recv ();  }      public function __destruct()  {    $this->client->clo ();    unt($this->client);  }}

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

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

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

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

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

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