资讯专栏INFORMATION COLUMN

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

superPershing / 2689人阅读

摘要:管理这些服务方案则叫服务治理。协议假定某些传输协议的存在,如或,为通信程序之间携带信息数据。请求程序就是一个客户机,而服务提供程序就是一个服务器。在服务器端,进程保持睡眠状态直到调用信息到达为止。

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

本猿人已经写好的服务治理 https://github.com/CrazyCodes...
治理什么?

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

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

UserService

ShopService

GoodsService

LiveService

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

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

User-Api

Shop-Api

Goods-Api

Live-Api

Service 是对内服务的而Api是对外服务的


图片来源 http://blog.csdn.net/suifeng3...

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

依托实现

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

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

$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/]

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/28321.html

相关文章

  • PHP序员如何简单开展服务治理架构(三)

    摘要:是一种使用松耦合的黑盒子服务构建业务应用的体系架构,这些服务可以通过编排连接在一起以实现特定的功能。在一个中如何实现松耦合实现松耦合一种策略是使用服务接口中为服务来限制服务之间的依赖性,对消费者隐藏服务实现。 服务治理所治理的服务需要合理的部署与管理,本章我们讲一下SOA(面向服务架构),本人语言文笔不好,所以本章内容使用问答模式,参考了 [SOA面试题(http://www.jdon...

    Dionysus_go 评论0 收藏0
  • PHP序员如何简单开展服务治理架构(二)

    摘要:服务治理治理的绝笔是服务,在一家公司有玩各种语言的程序员,如何去统一管理他们开发的服务,这是一个问题。请求程序就是一个客户机,而服务提供者就是一个服务器。在服务器端,进程保持睡眠状态直到调用信息到达为止。 服务治理 治理的绝笔是服务,在一家公司有玩各种语言的程序员,如何去统一管理他们开发的服务,这是一个问题。 上一章主要讲了下服务治理需要什么,如何实现,这章我们详细的肢解一下服务治理的...

    wing324 评论0 收藏0
  • 明星分分合合洪荒点击量,微博Mesh服务化改造如何支撑?(附PPT下载)

    摘要:为了解决这一系列问题,微博从年开发了语言的框架,并基于此完成了服务化改造。这些经历之下微博也积累了一套服务治理型的服务化体系。的版,所要解决的是微博平台内部服务之间的调用,因此协议时,其实并没有考虑到跨语言的问题,用的是对比较友好的。 showImg(https://segmentfault.com/img/remote/1460000012601596?w=1080&h=606); ...

    ShowerSun 评论0 收藏0
  • 华为数字化转型,你为什么就学不会?

    摘要:一引言华为数字化转型的逻辑和方法,看起来似乎并不非常复杂。华为在年提出实现全联接的智能华为,成为行业标杆的数字化转型目标。但是,华为的数字化转型之道真的好学吗其实不然。华为真正提出数字化转型,是在年。一、引言华为数字化转型的逻辑和方法,看起来似乎并不非常复杂。笔者将《华为.数字化转型必修课》课程的主要内容,概括为一个愿景、三大目标、四个基础、五大内容、三大要求、六大案例,用下图来表示: 一个...

    不知名网友 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<