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连接Oracle数据库
Oct 09 PHP
用PHP和ACCESS写聊天室(七)
Oct 09 PHP
php 变量未定义等错误的解决方法
Jan 12 PHP
PHP二维数组的去重问题解析
Jul 17 PHP
PHP输出缓存ob系列函数详解
Mar 11 PHP
PHP中__FILE__、dirname与basename用法实例分析
Dec 01 PHP
PHP查找数值数组中不重复最大和最小的10个数的方法
Apr 20 PHP
Zend Framework动作控制器用法示例
Dec 09 PHP
php利用云片网实现短信验证码功能的示例代码
Nov 18 PHP
PHP缓存工具XCache安装与使用方法详解
Apr 09 PHP
PHP命名空间用法实例分析
Sep 04 PHP
laravel框架邮箱认证实现方法详解
Nov 22 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
删除无限级目录与文件代码共享
2006/07/12 PHP
php strtotime 函数UNIX时间戳
2009/01/14 PHP
PHP设置一边执行一边输出结果的代码
2013/09/30 PHP
ecshop实现smtp发送邮件
2015/02/03 PHP
php获得客户端浏览器名称及版本的方法(基于ECShop函数)
2015/12/23 PHP
PHP自定义序列化接口Serializable用法分析
2017/12/29 PHP
PHP经典设计模式之依赖注入定义与用法详解
2019/05/21 PHP
Alliance vs Liquid BO3 第三场2.13
2021/03/10 DOTA
鼠标拖拽移动子窗体的JS实现
2014/02/25 Javascript
jQuery实现新消息在网页标题闪烁提示
2015/06/23 Javascript
jQuery Easyui快速入门教程
2016/08/21 Javascript
Laravel中常见的错误与解决方法小结
2016/08/30 Javascript
AngularJS封装指令方法详解
2016/12/12 Javascript
Vue.js实现表格动态增加删除的方法(附源码下载)
2017/01/20 Javascript
vue+vuex+axios实现登录、注册页权限拦截
2018/03/09 Javascript
JavaScript求一组数的最小公倍数和最大公约数常用算法详解【面向对象,回归迭代和循环】
2018/05/07 Javascript
element-ui table span-method(行合并)的实现代码
2018/12/20 Javascript
Koa 中的错误处理解析
2019/04/09 Javascript
vue2 中二级路由高亮问题及配置方法
2019/06/10 Javascript
js中offset,client , scroll 三大元素知识点总结
2019/09/11 Javascript
深入理解Javascript中的this关键字
2015/03/27 Python
浅谈Python中的闭包
2015/07/08 Python
Python基于回溯法子集树模板解决数字组合问题实例
2017/09/02 Python
Python实现自定义函数的5种常见形式分析
2018/06/16 Python
python 监听salt job状态,并任务数据推送到redis中的方法
2019/01/14 Python
python实现创建新列表和新字典,并使元素及键值对全部变成小写
2019/01/15 Python
python 类的继承 实例方法.静态方法.类方法的代码解析
2019/08/23 Python
python绘制彩虹图
2019/12/16 Python
STAY JAPAN台湾:预订日本民宿
2018/07/22 全球购物
大学生毕业求职的自我评价
2013/09/29 职场文书
内业资料员岗位职责
2014/01/04 职场文书
简单的大学生自我鉴定
2014/02/18 职场文书
职称评定自我鉴定
2014/03/18 职场文书
结婚老公保证书
2015/02/26 职场文书
受欢迎的自荐信,就这么写!
2019/04/19 职场文书
Java对文件的读写操作方法
2022/04/29 Java/Android