thrift、go与php

news2024/12/26 6:22:36

学习一下thrift。

环境
mac m1,go 1.20,php 7.4,thrift 0.18.1

要学习thrift,第一步得先安装

$ brew install thrift

学习的计划是用go作为server,php作为client,通过thrift的方式完成一次请求demo。

建个目录thrift_demo,然后在目录里完成go相关的操作。

先定义thrift文件,文件名就叫helloworld.thrift。

namespace go thrift_demo

service HelloWorld {
    string SayHello()
}

定义好之后,执行thrift指令来生成go代码

$ thrift --gen go helloworld.thrift

执行完成后,在当前目录就会生成gen-go目录,里面是thrift自动生成的go代码文件。
thrift生成的gen-go目录代码文件

用go做server,那就新建一个server.go文件,作为handler,来实现helloworld.thrift里定义的方法。

package main

import (
	"context"
	"fmt"
	"github.com/apache/thrift/lib/go/thrift"
	"thrift_demo/gen-go/thrift_demo"
)

type HelloWorldHandler struct{}

func (h *HelloWorldHandler) SayHello(ctx context.Context) (string, error) {
	return "Hello, world!", nil
}

func main() {
	handler := &HelloWorldHandler{}
	processor := thrift_demo.NewHelloWorldProcessor(handler)
	serverTransport, err := thrift.NewTServerSocket(":9090")
	if err != nil {
		panic(err)
	}

	transportFactory := thrift.NewTBufferedTransportFactory(1000000)
	protocolFactory := thrift.NewTBinaryProtocolFactoryDefault()
	server := thrift.NewTSimpleServer4(processor, serverTransport, transportFactory, protocolFactory)
	fmt.Println("Starting the server...")
	if err := server.Serve(); err != nil {
		panic(err)
	}
}

上面是server.go的代码,除了实现HelloWorldHandler之外,还启动了一个server来监听9090端口。

下面接着来写client,先用go写一版试试。

package main

import (
	"context"
	"fmt"
	"github.com/apache/thrift/lib/go/thrift"
	"thrift_demo/gen-go/thrift_demo"
)

func main() {
	transport, err := thrift.NewTSocket("localhost:9090")
	if err != nil {
		panic(err)
	}
	defer transport.Close()
	if err := transport.Open(); err != nil {
		panic(err)
	}

	protocolFactory := thrift.NewTBinaryProtocolFactoryDefault()
	client := thrift_demo.NewHelloWorldClientFactory(transport, protocolFactory)
	result, err := client.SayHello(context.Background())
	if err != nil {
		println(err.Error())
		panic(err)
	}
	fmt.Println(result)
}

server和client都写完后,来执行一下看看

$ go run server.go

先启动server端,再启动client

$ go run client.go
Hello, world!

能看到返回的输出就是HelloWorldHandler里实现的sayHello()方法的输出,请求链路是通的。

下面就来写一下php client。
首先需要用thrift生成php代码

$ thrift --gen php helloworld.thrift

执行完成后,会生成gen-php目录已经相关的php代码文件
在这里插入图片描述
这里需要将gen-php目录拷贝出来,放到php代码目录下面,然后再编写php版本的client.php

<?php
namespace ttt\php;
error_reporting(E_ALL);

require_once "vendor/autoload.php";
require __DIR__."/gen-php/HelloWorldClient.php";

use \Thrift\ClassLoader\ThriftClassLoader;
use Thrift\Protocol\TBinaryProtocol;
use Thrift\Transport\TBufferedTransport;
use Thrift\Transport\TSocket;
use Thrift\Exception\TException;

$GEN_DIR = dirname(__FILE__).'/gen-php';

$loader = new ThriftClassLoader();
$loader->registerNamespace('Thrift', __DIR__.'/vendor/apache/thrift/lib/php/lib');
$loader->registerDefinition('Services', $GEN_DIR);
$loader->register();

try {
    $socket = new TSocket('localhost', 9090);
    $trans = new TBufferedTransport($socket, 1024, 1024);
    $protocol = new TBinaryProtocol($trans);
    $client = new \HelloWorldClient($protocol);

    $trans->open();
    $ret = $client->SayHello();
    var_dump($ret);
} catch (\TException|\Exception $e) {
    var_dump($e->getMessage());
}

写完之后执行一下

$ php client.php 

Warning: require(./HelloWorldIf.php): failed to open stream: No such file or directory in /Users/myStudy/gen-php/HelloWorldClient.php on line 8

Fatal error: require(): Failed opening required './HelloWorldIf.php' (include_path='.:/opt/homebrew/Cellar/php@7.4/7.4.24_1/share/php@7.4/pear') in /Users/myStudy/gen-php/HelloWorldClient.php on line 8

报错了,意思是HelloWorldClient.php里没有找到依赖文件,把它需要的给它补上。
修改gen-php/HelloWorldClient.php文件,增加如下内容

require 'HelloWorldIf.php';
require 'HelloWorld_SayHello_args.php';
require 'HelloWorld_SayHello_result.php';

然后再次运行client

$ php client.php 
string(13) "Hello, world!"

成了。


其中,可能需要解决一些依赖问题,php的包可以使用

"apache/thrift": "^0.18.1"

go可以使用

require github.com/apache/thrift v0.18.1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/458704.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java语言的特点和八大基本类型

“byte和short两兄弟去找int问long去哪了” “int摇摇头说不知道” “此时float和double两兄弟也来凑热闹” “共同商议后决定去找char询问” “char面对五人的询问只好说boolean知道” “六人来到boolean的住处发现long竟然在玩猜真假游戏” Java语言的特点 1.简单易学…

个性化学习路径推荐综述

源自&#xff1a;软件学报 作者&#xff1a;云岳 代欢 张育培 尚学群 李战怀 摘 要 近年来, 伴随着现代信息技术的迅猛发展, 以人工智能为代表的新兴技术在教育领域得到了广泛应用, 引发了学习理念和方式的深刻变革. 在这种大背景下, 在线学习超越了时空的限制,…

2023年电信推出新套餐:月租19元=135G流量+长期套餐+无合约期!

在三大运营商推出的流量卡当中&#xff0c;电信可以说是性价比最高的一个&#xff0c;相对于其他两家运营商&#xff0c;完全符合我们低月租&#xff0c;大流量的要求&#xff0c;所以&#xff0c;今天小编介绍的还是电信流量卡。 在这里说一下&#xff0c;小编推荐的卡都是免…

教你怎样用PXE高效的批量网络装机

目录 一&#xff1a;PXE介绍 1.XPE概述 2.PXE批量部署的优点 3.搭建PXE各部作用 &#xff08;1&#xff09;PXE(Preboot eXcution Environment) &#xff08;2&#xff09;服务端 &#xff08;3&#xff09;客户端 二&#xff1a;部署PXE服务 1.安装并启用TFTP服务 2.安…

Tiktok/抖音旋转验证码

声明 本文以教学为基准、本文提供的可操作性不得用于任何商业用途和违法违规场景。 本人对任何原因在使用本人中提供的代码和策略时可能对用户自己或他人造成的任何形式的损失和伤害不承担责任。 如有侵权,请联系我进行删除。 抖音系的旋转验证码,跟得物一样,都是内外圈一起…

blast的-max_target_seqs?

Shah, N., Nute, M.G., Warnow, T., and Pop, M. (2018). Misunderstood parameter of NCBI BLAST impacts the correctness of bioinformatics workflows. Bioinformatics. 杂志Bioinformatics以letter to the editor的形式刊发了来自美国马里兰大学计算机系的Nidhi Shah等人…

基于html+css的图展示42

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

安卓设备远程管理软件

现在&#xff0c;安卓设备广泛应用于各类智能硬件&#xff0c;有时候我们需要远程管理这些安卓设备。远程管理软件使 IT 管理员能够从任何地方控制和管理安卓设备&#xff0c;确保它们安全、最新并以最佳水平运行。在本文中&#xff0c;我们将介绍一些当前主流的安卓设备远程管…

Automa函数学习(三)

从变量中获取数据 当我们想要用automa获取文本标签获取到网页的文本内容后,想要将获取到的文本内容当做参数往后面的标签里进行传递时就需要用到automa提供的传参格式 {{ variables.自定义参数名}} 举例: 先建立打开百度首页工作流 前面自定义的变量名为text,所以这里参数拼接…

云计算的未来发展趋势与优势,你是否了解?

作者简介&#xff1a;一名云计算网络运维人员、每天分享网络与运维的技术与干货。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​​ 目录 前言 一、企业痛点 1.企业信息技术应用痛点 二、云计算的基础概念 1.什么是云计…

纯享三代HiFi reads,至美细菌完成图,加送质粒基因组!

三代测序时代&#xff0c;PacBio High-Fidelity reads在基因组组装中大放异彩。HiFi测序模式可产生既兼顾长读长&#xff0c;又具有高精度的测序结果。凌恩生物HiFi细菌基因组完成图测序&#xff0c;即利用PacBio HiFi测序模式对某细菌物种进行基因组de novo组装&#xff0c;从…

安科瑞充电方案解决电瓶车充电难、管理难、收费难问题

安科瑞 徐浩竣 江苏安科瑞电器制造有限公司 zx acrelxhj 0引言 电动自行车已经成为重要的出行工具&#xff0c;数量肯定还会继续增长&#xff0c;各级政府部门和物业管理者已经对其带来的消防隐患引起高度重视。安科瑞电动自行车运营管理云平台通过充电桩、云平台、APP小程…

Spring框架及源码(二)---Spring IoC高级应用与源码剖析

Spring IOC 应用 第1节 Spring IoC基础 Spring框架下IOC实现&#xff0c;解析bean的几种方式 1.1 BeanFactory与ApplicationContext区别 BeanFactory是Spring框架中IoC容器的顶层接⼝,它只是⽤来定义⼀些基础功能,定义⼀些基础规范,⽽ ApplicationContext是它的⼀个⼦接⼝&a…

Testudo:Spartan + Groth16 的R1CS ZKP证明系统

1. 引言 前序博客有&#xff1a; Spartan: zkSNARKS without trusted setup学习笔记Spartan: zkSNARKS without trusted setup 源代码解析Signatures of Correct Computation 学习笔记&#xff08;本文称为PST承诺方案&#xff09;Groth16 学习笔记ZCash bellman版本 Groth16…

Spring Boot的日志文件

目录 日志的作用 日志的打印 常见的日志框架 自定义的日志打印 为什么不用sout来打印日志 Spring Boot日志打印 1.得到日志对象 2.使用日志对象提供的方法打印日志 日志级别 日志级别的顺序 日志级别的设置 日志持久化 配置日志文件的保存路径 配置日志文件的文件…

学习spark笔记

✨ 学习 Spark 和 Scala 一 ​ &#x1f426;Spark 算子 spark常用算子详解&#xff08;小部分算子使用效果与描述不同&#xff09; Spark常用的算子以及Scala函数总结 Spark常用Transformations算子(二) Transformation 算子(懒算子)&#xff1a;不会提交spark作业&#…

AWT——事件处理机制

事件处理&#xff1a; 定义&#xff1a; 当某个组件上发生某些操作的时候&#xff0c;会自动地触发一段代码的执行 在GUI事件处理机制中涉及到4个重要的概念需要理解。 事件源&#xff1a;操作发生的场所&#xff0c;通常指某个组件&#xff0c;例如按钮、窗口等 事件&…

Spring Boot Web请求

在上一讲&#xff0c;学习了Spring Boot Web的快速入门以及Web开发的基础知识&#xff0c;包括HTTP协议以及Web服务器Tomcat等内容。基于SpringBoot的方式开发一个web应用&#xff0c;浏览器发起请求 /hello 后 &#xff0c;给浏览器返回字符串 “Hello World ~”。运行启动类启…

不能接受就滚,某外卖企业在汕尾的蛮横做法,或是它衰退的开始

近期某外卖平台因为大举降低外卖骑手的单价&#xff0c;引发高度关注&#xff0c;直到汕尾的外卖骑手集体抵制&#xff0c;引发与该外卖平台的激烈博弈&#xff0c;而外卖平台也显示了它的强硬手段&#xff0c;此举只会进一步激化矛盾&#xff0c;进而导致该外卖企业的衰落。 据…

Nginx的优化和防盗链

一、隐藏版本号 1、隐藏版本号的操作步骤 可以使用 Fiddler 工具抓取数据包&#xff0c;查看 Nginx版本&#xff0c; 也可以在 CentOS 中使用命令 curl -I http://192.168.229.90 显示响应报文首部信息。 curl -I http://192.168.2.661.1、方法一&#xff1a;修改配置文件方…