第 8 章 互操作性


本章讨论了如何将 AMQ Ruby 与其他 AMQ 组件结合使用。有关 AMQ 组件的兼容性概述,请参阅 产品简介

8.1. 与其他 AMQP 客户端交互

AMQP 消息使用 AMQP 类型系统 组成。这种通用格式是以不同语言的 AMQP 客户端能够相互互操作的原因之一。

在发送消息时,AMQ Ruby 会自动将语言原生类型转换为 AMQP 编码的数据。收到信息时,反向转换就发生。

注意

有关 AMQP 类型的更多信息,请访问由 Apache Qpid 项目维护 的交互式类型参考

表 8.1. AMQP 类型
AMQP 类型描述

null

一个空值

布尔值

true 或 false 值

char

单个 Unicode 字符

string

一系列 Unicode 字符

二进制

一个字节序列

byte

签名的 8 位整数

short

签名的 16 位整数

int

签名的 32 位整数

long

签名的 64 位整数

ubyte

未签名的 8 位整数

ushort

未签名的 16 位整数

uint

未签名的 32 位整数

ulong

未签名的 64 位整数

浮点值

32 位浮点号

double

64 位浮点号

数组

单个类型的值的序列

list

变量类型的序列值

map

从不同键到值的映射

uuid

通用唯一标识符

符号

来自受限域的 7 位 ASCII 字符串

timestamp

一个绝对时间点

表 8.2. 在编码前和解码后 AMQ Ruby 类型
AMQP 类型在编码前 AMQ Ruby 类型解码后 AMQ Ruby 类型

null

nil

nil

布尔值

true, false

true, false

char

-

字符串

字符串

字符串

字符串

二进制

-

字符串

byte

-

整数

short

-

整数

int

-

整数

long

整数

整数

ubyte

-

整数

ushort

-

整数

uint

-

整数

ulong

-

整数

浮点值

-

浮点值

double

浮点值

浮点值

数组

-

Array

list

Array

Array

map

hash

hash

符号

符号

符号

timestamp

日期、时间

Time

表 8.3. AMQ Ruby 和其他 AMQ 客户端类型(2 为 1)
在编码前 AMQ Ruby 类型AMQ C++ 类型AMQ JavaScript 类型

nil

nullptr

null

true, false

bool

布尔值

字符串

std::string

字符串

整数

int64_t

number

浮点值

double

number

Array

std::vector

Array

hash

std::map

object

符号

proton::symbol

字符串

日期、时间

proton::timestamp

number

表 8.4. AMQ Ruby 和其他 AMQ 客户端类型(2 个)
在编码前 AMQ Ruby 类型AMQ .NET 类型AMQ Python 类型

nil

null

None

true, false

system.Boolean

bool

字符串

system.String

unicode

整数

System.Int64

long

浮点值

system.Double

浮点值

Array

Amqp.List

list

hash

Amqp.Map

dict

符号

Amqp.Symbol

str

日期、时间

System.DateTime

long

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.