Thrift前端上手实例

项目介绍

项目地址

这个项目用来帮助那些对thrift感兴趣的前端们上手thrift, 你可以把它认为是一个简易的使用案例或是指南, 毕竟thrift的官方文档真的很简单...

为什么使用Thrift

Thrift是一种接口描述语言和二进制通讯协议, 可以用来进行服务端与服务端的通信。 与http相比他有很多优点:

  • 跨语言,自动生成不同语言的接口代码,这在开发中用处很大,可以使你在联调之前就确保传输的参数类型和字段没有问题,大大减少bug出现率。
  • 与HTTP相比更加紧凑,但同时可扩展性也很强,支持加密、非阻塞、异步等功能。
  • 数据传输效率高,负载低,支持多种序列化技术。

一些劣势:

  • 接口代码根据IDL自动生成,当数据结构变化时,需重新编辑IDL文件,生成代码。( 这一点可以通过写脚本解决这个问题 )
  • 社区和技术文档很不全面。

以上都是一些在哪都能查得到的优劣对比...

其实当前端业务越来越复杂, 后端所提供的服务不管是数量还是种类都越来越多, RPC协议的重要性才会凸显出来, 因为一个前端应用需要调用各种服务, 需要一个中间层来做不同服务的整合, 中间层与真正后端的通信使用像Thrift这样的RPC协议就再合适不过了。 其实项目架构中的图主要就解释了这一点。( 如果有读者对这个不是很了解可以阅读一下我的这篇 日记

注意 : 这个项目主要是为前端们提供上手帮助而非细节讲解。

项目架构

以我对thrift一些浅薄的理解,它的应用整体架构因该是如下图所示的:

主要的文件结构

-|
 |- client                 // 前端
 |                          
 |- middle                 // 中间层
 |  
 |- server                 // 真正的后端
 |
 |- thrift -|              // 存放与thrift相关文件的文件夹
            |
            |- gen-nodejs  // 存放.js文件的文件夹
            |
            |- .thrift     // 存放.thrift文件的文件夹

 // 注意:
 这个项目使用node作为服务端的开发语言,  
 部分代码衍生自官网的实例,  
 但是它比官网的代码更加完整,  
 可以让你了解thrift的完整使用流程。

将会被用到的前端框架或前端库以及使用原因:

  • 客户端 : vue 使用原因 : 尝试一下而已,但是使用vue-cli构建项目真的很方便,对vue不熟悉的渎职只需关注 @client/src/App.vue 中的代码即可;
  • 中间层 : koa做router处理, thrift连接真正的后端 使用原因 : 因为它是一个真的很轻量的nodejs库,作为demo真的是再适合不过了;
  • 服务端 : thrift 使用原因 : 通常的,这里会使用java等一些稳定高效的后端语言,但是为了方便前端们的阅读也为了方便编写,这里还是使用node.

如何使用

  • 首先你需要通过 npm run server 启动服务端的服务;
  • 接下来你需要通过 npm run middle 启动中间层的服务;
  • 最后你需要 cd client 进入client文件夹,并执行 npm run dev 来启动客户端;
  • 当你在客户端出发事件,你将看到从服务端传回的数据,追踪数据的流向,你将明白thrift的使用方式。

数据流向图:

最后

文章内容是个人的一些理解,如果阅读的同学觉得有问题可以及时的与我沟通。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏韩伟的专栏

可用于集群的开源软件赏:Chef

目前我在腾讯主要负责一个服务器端软件的相关开源项目,所以接下来几天的开源内容是最近工作上积累的一些经验和想法,下图中的内容就是我目前主要的工作内容和一些小小的成...

3816
来自专栏京东技术

京东JMAC,完美解决移动自动化测试的常见问题

提到移动端自动化测试就不得不提及目前几大开源的移动端自动化测试工具/框架,主流工具有Appium、Athrun、Robotium、UiAutomator、Mon...

872
来自专栏大数据学习笔记

Java软件工程师面试题汇总(持续更新)

实战问题 1、一个请求超过20秒了,你怎么排查和解决; 2、说说你觉得做的比较不错的项目,讲一下项目结构和用到的框架,再说一下为什么要选择这些框架; 3、“商品...

19710
来自专栏编程

Node.js VS PHP—你应该选择哪一个?

现在,WEB开发公司和开发人员可以选择多种技术栈来构建Web应用程序。早期网络发展,不同的技术被用于前端和后端开发。但是,随着Node.js的发布,布局发生了变...

2977
来自专栏Rainbond开源「容器云平台」

好雨云帮更新志( 2017.04.03-2017.04.16)

1082
来自专栏技术分享

.NET应用架构设计—面向查询服务的参数化查询设计(分解业务点,单独配置各自的数据查询契约)

阅读目录: 1.背景介绍 2.对业务功能点进行逻辑划分(如:A、B、C分别三个业务点) 2.1.配置映射关系,对业务点配置查询契约(构造VS插件方便生成查询契...

1988
来自专栏13blog.site

Spring+SpringMVC+MyBatis+easyUI整合进阶篇(一)设计一套好的RESTful API

写在前面的话 看了一下博客目录,距离上次更新这个系列的博文已经有两个多月,并不是因为不想继续写博客,由于中间这段时间更新了几篇其他系列的文章就暂时停止了,如今已...

2745
来自专栏刘明的小酒馆

使用Docker三剑客部署集群

DOCKER技术在推出后掀起了一阵容器化技术的热潮,容器化使得服务的部署变得极其简易,这为微服务和分布式计算提供了很大的便利。

5616

API-First,Kubernetes上微服务的一种方法

对那些曾经使用更传统方式构建应用的开发者来说,转向容器化微服务不是一个容易的转变。当开发者设计分布式应用时,微服务应用也正是分布式的,其中有许多新的概念和细节需...

1704
来自专栏张善友的专栏

深入浅出事件流处理NEsper(一)

    对实时信息分析和处理,常常需要客户应用程序的开发相应功能。一般地,这些功能需要提供以下的处理流程,分析获取的数据,筛选数据,提取出有用的信息,然后将其通...

1969

扫码关注云+社区