- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的应用程序中,有几个组件将生成各种不同类型的应用程序特定事件。这些事件将发布给经纪人并传递给 N 个客户。其中一些客户端是我的服务器端应用程序中的其他 Java 类,但主要使用者是我基于 javascript 的 WebUI。
到目前为止,我当前的方法是定义一个抽象事件基类来封装一些公共(public)字段,然后为每个事件实现一个特定的事件类。
这一直工作得很好,除了现在我需要在 javascript 和 java 端维护该事件,以便任何一方都可以对其他事件使用react。
今天早上我有一个想法,我可以利用 Thrift(该项目已经大量使用它)来定义事件数据结构并自动生成两侧的类。这不仅处理了编写类文件的繁琐工作,而且确保了一致性。
我的问题是,由于 thrift 中的数据对象是结构(无法扩展),我无法封装公共(public)字段,也无法使用单个基类传递事件。
到目前为止,我想出的解决方法是在 thrift IDL 中定义一个结构体来充当“基”类,并为我定义的每个事件类型提供一个可选字段。这仍然让我有一个类来一般地引用事件,同时还让我在生成事件时捕获相关数据。
也许这只是我对thrift不太熟悉,但这感觉就像一个黑客。我是否离题了,或者这是一个不错的方法吗?有没有更好的方法来实现这一点?
最佳答案
Thrift 作为一种序列化和 RPC 机制,仅允许一对一连接,因此并不能真正解决任务。但你并没有迷失方向。
如果你想做一对多,你应该使用一些消息系统。 Thrift 可以轻松地与各个级别的消息传递系统相结合。 /contrib
folder源代码树包含一些关于如何实现这一目标的示例。
使用 Thrift union
作为信封来保存所有各种数据结构是一个有效的解决方案,因为它允许最大限度地减少序列化和反序列化代码 - 您只需要一对函数来处理始终相同的 Envelope
结构(当然可能有不同的内容)。
struct Foo { ... some member fields ... }
struct Bar { ... some member fields ... }
struct Baz { ... some member fields ... }
union Envelope {
1: Foo foo
2: Bar bar
3: Baz baz
}
关于javascript - 有没有一种干净的方法来使用 thrift 定义事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32698551/
我正在使用 Ubuntu 10.04 LTS 机器,我在该机器上克隆了 Thrift 的 git 存储库并从源代码本地构建它。但是最新版本的 API 有一些变化,这导致应用程序的构建过程失败。 由于仅
尽管 Thrift 格式使用相对广泛(并且项目仍然存在),但我无法找到底层数据格式的规范。或格式,因为显然至少有两种格式;标准之一,紧凑的格式。 鉴于它的广泛使用,我希望它只是我可怜的 google-
每个参数(字段标识符)之前的数字的用途是什么?为什么从 5 跳到 16? struct Tweet { 1: required i32 userId; 2: required stri
我已经在 mac 中安装了 thrift。 从终端看起来 thrift 已成功安装但是当我尝试运行 thrift 命令时,我得到以下信息 Thrift: command not found 我从终端使
我在 c++ 中有一个结构,它存储这样的字节: struct RemoteData { /// some other fields here unsigned char* buf;
我想在 IDL 文件中定义几个结构。然后在服务中返回该结构类型的对象。为此,我必须导入该结构。如何在 IDL 中导入它们。 namespace java abc.xyz struct struct_{
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我使用thrift编译器(0.9.3)生成gen-go文件夹,同时编译器生成一个函数thrift.PrependError,在thrift 包(git.apache.org/thrift.git/li
假设我在包含两个字段的 Apache Thrift IDL 文件中定义了一个结构。例如: struct Thing { 1: optional string name, 2: optional
是否有可能使用 Thrift 来表示诸如 Java 类型 Map 之类的东西,其中 Map 中的值是已知的,例如是字符串还是整数? 换句话说,是否有任何方法来表示实际基类型仅在运行时已知但保证是一组预
我需要使用 Ruby 实现 Thrift API。 在生产环境中运行服务器有哪些选项? 最好的选择是什么? 目前我只是实例化一个 SimpleServer 并在其上调用 #serve。这显然是一个蹩脚
我正在查看 thirft 代码生成器的文档。它是这样开始的: Usage: thrift [options] file Options: -version Print the compile
所有教程和文档都建议每个 Thrift 服务器可以提供一项服务(1 个处理程序 1 个处理器 1 个服务器,全部在构造函数等中给出)。 从我的观点(优雅的设计)来看,如果许多或所有服务定义可以独立会更
我正在寻找 C++ 异步客户端和非阻塞 C++ 服务器实现。我在 apache 中看到一些邮件文件,但该事件是 2009 年末的。想知道最新的 thrift 是否支持它。我正在对 C++ 代码使用 c
我一直在研究使用 Apache Thrift,但发现文档有些缺乏。现在我有兴趣看到支持的目标语言以及每种语言支持的协议(protocol),是否有这样的矩阵? 最佳答案 试试这个: Thrift La
使用 C++ Apache Thrift 库,是否可以仅使用序列化/反序列化而不使用 RPC 服务? 据我了解 this页面,可以使用 Java 库来完成。但是,我找不到 C++ 库的类似类。 最佳答
Thrift 解析器有一个“注解”的定义: https://git-wip-us.apache.org/repos/asf?p=thrift.git;a=blob;f=compiler/cpp/src
我的组织设置了一个 Spark Thrift 服务器,该服务器配置为使用 HTTP 上的 SSL。目的是使 Power BI 能够通过 Spark 安全地检索数据。然而,仅仅检索架构信息可能需要长达
我正在我的 Mac 上运行一对使用 Apache Thrift 进行通信的客户端和服务器程序。在我们的生产系统中,我们可能最终会遇到客户端使用TJSONProtocol,服务端使用TBinaryPro
来自 Thrift website 的示例 int multiply(1:int n1, 2:int n2); 为什么我们必须使用标签 1:和 2:在变量名之前,这个标签的目的是什么? 最佳答案 这些
我是一名优秀的程序员,十分优秀!