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


Posted in PHP onMay 14, 2020

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

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

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

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

暂时大可理解为可以通过它去调用其他开发语言的方法
本猿人已经写好的服务治理 https://github.com/CrazyCodes/Service-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通信协议开发出了一套thrift

实现方法

  • 上面假设你都没看懂,这里我们实战下。
  • 首先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();

往期文章

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

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
php重定向的三种方法分享
Feb 22 PHP
zf框架的session会话周期及次数限制使用示例
Mar 13 PHP
php+mysql不用递归实现的无限级分类实例(非递归)
Jul 08 PHP
php将文本文件转换csv输出的方法
Dec 31 PHP
PHP获得数组交集与差集的方法
Jun 10 PHP
在php中设置session用memcache来存储的方法总结
Jan 14 PHP
PHP执行linux命令常用函数汇总
Feb 02 PHP
非常有用的9个PHP代码片段
Apr 06 PHP
php curl 模拟登录并获取数据实例详解
Dec 22 PHP
Laravel中批量赋值Mass-Assignment的真正含义详解
Sep 29 PHP
thinkPHP5框架自定义验证器实现方法分析
Jun 11 PHP
PHP程序员简单的开展服务治理架构操作详解(三)
May 14 PHP
PHP程序员简单的开展服务治理架构操作详解(一)
May 14 #PHP
PHP程序员必须知道的两种日志实例分析
May 14 #PHP
Laravel框架集合用法实例浅析
May 14 #PHP
Laravel框架源码解析之模型Model原理与用法解析
May 14 #PHP
Laravel框架源码解析之入口文件原理分析
May 14 #PHP
Laravel框架源码解析之反射的使用详解
May 14 #PHP
PHP 数组操作详解【遍历、指针、函数等】
May 13 #PHP
You might like
php判断GIF图片是否为动画的方法
2020/09/04 PHP
如何利用http协议发布博客园博文评论
2015/08/03 PHP
php数字每三位加逗号的功能函数
2015/10/22 PHP
Laravel 批量更新多条数据的示例
2017/11/27 PHP
php实现将数据做成json的格式给前端使用
2018/08/21 PHP
PHP开发实现快递查询功能详解
2019/04/08 PHP
js获取当前日期代码适用于网页头部
2013/06/27 Javascript
javascript 应用小技巧方法汇总
2015/07/05 Javascript
jquery专业的导航菜单特效代码分享
2015/08/29 Javascript
jQuery实现下拉框左右移动(全部移动,已选移动)
2016/04/15 Javascript
jQuery.Callbacks()回调函数队列用法详解
2016/06/14 Javascript
js 上传文件预览的简单实例
2016/08/16 Javascript
jQuery html表格排序插件tablesorter使用方法详解
2017/02/10 Javascript
简单实现js倒计时功能
2017/02/13 Javascript
详解js类型判断
2018/05/22 Javascript
详解webpack打包后如何调试的方法步骤
2018/11/07 Javascript
JS监听事件的叠加和移除功能
2018/11/19 Javascript
详解用JS添加和删除class类名
2019/03/25 Javascript
jQuery实现的记住帐号密码功能完整示例
2019/08/03 jQuery
vue-router 中 meta的用法详解
2019/11/01 Javascript
python让图片按照exif信息里的创建时间进行排序的方法
2015/03/16 Python
python实现将文本转换成语音的方法
2015/05/28 Python
Python深入06——python的内存管理详解
2016/12/07 Python
python利用paramiko连接远程服务器执行命令的方法
2017/10/16 Python
机器学习之KNN算法原理及Python实现方法详解
2018/07/09 Python
Python数据类型之Tuple元组实例详解
2019/05/08 Python
python socket通信编程实现文件上传代码实例
2019/12/14 Python
详解Python的爬虫框架 Scrapy
2020/08/03 Python
MAC平台基于Python Appium环境搭建过程图解
2020/08/13 Python
python爬虫线程池案例详解(梨视频短视频爬取)
2021/02/20 Python
财务会计专业毕业生自荐信
2013/10/19 职场文书
物流专业大学生的自我鉴定
2013/11/13 职场文书
大二法英学生职业生涯规划范文
2014/02/27 职场文书
酒店管理求职信
2014/06/09 职场文书
检讨书格式
2015/05/07 职场文书
中小企业员工手册范本
2015/05/14 职场文书