grp是什么意思中文翻译(grpa是什么意思)

时间:2024-01-17 20:25:34 来源:互联网 编辑:浮生如梦

揭秘“电子脚镣”有6大功能

电子镣铐是一种电子监察装置

我们通常说的电子脚镣是一种电子监察装置,是发达资本主义国家对嫌犯一种监视工具。既保障了,又不至于使嫌犯脱逃。我国的台湾省、韩国、澳大利亚、加拿大等国家都在使用。

2018年,在澳洲涉嫌 的高云翔被保释成功,保释的附加条件是:住在董璇所租的单位、每天必须到警局报道两次、交出本人及母亲和女儿护照、不得接近机场、不得接触受害人、佩戴电子监控设备监控行踪、每天9点到下午5点必须在家。这个电子监控设备,也就是俗称的电子脚镣。

高云翔/头条图库

虽然这些条件限制一定的人身自由,但能与亲人待在一起已经够好了。

在韩国,凡是有两次以上性暴力犯罪史,或对未成年人实施犯的刑满释放人员,以及获得假释或者缓期执行需监视居住的犯罪人员,都要强制佩戴“电子脚镣”。

2015年,3名未成年少女的韩国歌手高英旭刑满出狱,但他还得继续戴着电子脚镣3年,出狱时可以明显看到他裤子下的“电子脚镣”轮廓。

韩国歌手高英旭

它的工作原理会让警方24小时定位追踪佩戴“电子脚镣”的人,当佩戴者进入禁入区域,电子脚环就会强烈震动。如果受监督者对电子脚环进行破坏,未携带专用手机,不接听专用手机,都会接到警报。佩戴者擅自分离、损坏、拆解电子装置,将受到严厉的处罚。

通过加拿大唯一一家SafeTracks GPS电子脚镣供应商,了解电子镣铐功能性工作原理。

首先,监控电子脚镣一般内置GPS功能,上述提及的XC3正设有GPS追踪功能,每随2秒就会更新GPS资料,而GPS位置的准确度介于1.8m至15m。

第二,XC3电子脚镣设有2或3方实时语音通讯功能,监控单位可以随时通过系统,与保释者对话,脚镣设有收音及喇叭系统。

第三,电子脚镣设有警报器,可以发出警笛声、一般声响、LED灯、震动等。若犯人逃走,脚镣会发出警笛声,提醒公众有逃犯。

第四,电子脚镣依靠电讯网络商的资料传送。以XC3为例,能自动从加拿大的AT&T及T-Mobile网络切换,支援GRPS、EDGE、UMTS及S技术。

第五,电子脚镣可以预先设定保释者的活动范围,一旦走出指定范围,监控当局就会即时知道,并做出进一步行动。

第六,以XC3电子脚镣为例,它拥有6米防水功能,可工作气温从-20℃至60℃,这代表保释者即使24小时佩戴也没有问题。

另外,该电子脚镣高约120毫米、宽为88.9毫米,重量为274.9克,一次充满电可用50~56小时。

REST 和 gRPC 详细比较

译者注:在微服务架构设计,构建API和服务间通信技术选型时,对 REST 和 gRPC 的理解和应用还存在知识盲区,近期看到国外的这篇文章:A detailed comparison of REST and gRPC[1],将二者进行了详细对比。周末有时间翻译过来,希望能帮到大家!

很长一段时间以来,REST是构建API的唯一“标准”。近年来,出现了新的替代方案。2015年,脸书发布了GraphQL,2016年谷歌紧随其后发布了gRPC,被广泛使用。在本文中,将关注gRPC,并将其与REST进行比较。

概述

下表将概述本文讨论的要点,并显示 REST 和 gRPC 真正的亮点。

主题RESTgRPC
标准化无标准定义明确
范式以资源为中心以服务方法为中心
服务模式一元流一元流、客户端流、服务器流和双向流
要求任何 HTTP、Json解析编程语言需要支持 HTTP/2, gRPC
API 设计代码优先设计优先
默认数据格式JsonProtobuf
WEB浏览器支持浏览器本地支持gRPC WEB
工具成熟的工具特定编程语言工具
标准化

REST 缺点之一是缺乏标准化,与其说 REST 是一个API标准,不如说是一种范式。许多人在谈论它时都有不同的含义。对大多数人来说,术语“REST API”是基于HTTP的JSON API;对于其他规范,REST 可以与某些规范(如:HATEOAS[2]或 JSON:API[3])互换使用。

REST这个术语甚至与HTTP无关。在使用 REST API 时,可能会导致很多混乱。例如,即使没有明确定义,使用者可能会期望某些 REST API 端点的幂等性或可缓存性。

相比之下,gRPC定义得很好。例如,基于 HTTP/2 的gRPC实现非常详细。

基本差异

REST 和 gRPC 的范式并不相同。

REST 一切都以资源为中心,这些资源可以被检索和操作。如果以图书作为示例资源,REST API通常会提供以下端点:

• GET /books :检索所有书,可带有筛选和分页结果的参数

• GET /books/{id} :检索指定ID书

• POST /books :创建书

• DELETE /books/{id} :删除书

大多数基于 HTTP 的 REST API 都遵循这种模式。这很好,但某些情况很难表示为 REST API。例如,如果想创建多本书,而不想为每本书重复调用 POST/books(出于性能、幂等性或其他原因),该怎么办?是否应该创建 POST/books/batch 端点?这还是“RESTful”吗?虽然在技术上容易解决,但开发人员之间经常会进行长时间的讨论。

另一方面,gRPC是一个RPC框架,以服务方法为中心。如果以图书 API为例,使用gRPC,将使用以下方法创建 BookService :

• GetBooks()

• GetBook()

• CreateBook()

• DeleteBook()

可以随心所欲地命名这些方法,并设置任何需要的参数。如果现在想添加一个方法来创建多本书,没有什么能阻止我们添加 CreateBooks() 方法。gRPC 在设计 API 时提供了更多的“自由”,因为有更少的(自我强加的)限制。

服务模式

gRPC 支持四种服务方法:

• 一元流:发送单个请求,接收单个响应。

• 服务器流:发送单一请求,接收多个响应。

• 客户端流:发送多个请求,接收单一响应。

• 双向流:发送多个请求,接收多个响应。

与只支持一元请求的 REST 相比,gRPC 有一个非常好的优势。在 REST API 中支持其他服务模式需要使用不同的协议,例如:服务器发送的事件或websocket,这不是很“RESTful”。

要求

REST API通常“只适用于”任何类型的 HTTP 版本。只要一种编程语言有一个 HTTP 客户端和一个用于 JSON 解析的库,那么使用 REST API 就轻而易举了。

gRPC 明确需要 HTTP/2 支持,否则它将无法工作。近年来,由于大多数框架都增加了对 HTTP/2 的支持,这已经不再是一个问题了。

由于 gRPC 需要生成代码(用于创建客户端或服务器存根),因此仅部分编程语言支持,查看编程语言列表[4]。

API 设计

REST API 通常是其实现的结果,称为“代码优先(code-first)”。虽然可以先用 OpenAPI 设计API,然后生成服务器存根,但这不是许多开发人员采用的方法。如果有一个 OpenAPI 定义,那么 OpenAPI 定义很可能是从 API 实现生成的。因此,API定义与实现紧密耦合。模型类的更改可能会导致 API 更改,无意中破坏接口规范。

gRPC 使用不同的方法,在实现API之前必须定义API(称为“设计优先(design-first)”)。然后根据 API 定义生成客户端和服务器存根。这需要提前考虑,因为不能直接实现API。

两种方法各有利弊。通常 REST API 方法允许快速迭代;使用gRPC,在调整 API 实现之前首先更改 API 定义,这可能会很烦人。然而,通过显式定义API更加安全,API变动没那么随意。

数据格式

REST 和 gRPC 都可以使用不同的格式来传输数据。大多数 REST API 使用JSON,而 gRPC 默认使用 Protocol Buffers[5],一种轻便高效的结构化数据存储格式,因此我们将比较这两者。

JSON 对数据类型的支持有限,例如,大数字需要表示为字符串。JOSON 是一种文本格式,便于阅读。字段名序列化会占用一些空间。在一些编程语言中,还需要使用反射来反序列化 JSON 消息,速度慢。

如上所述,gRPC API 和相应的消息类型首先被定义为 Protocol Buffers 。每条消息都是强类型的,对于支持的编程语言,可以自动生成代码以(反)序列化消息。由于它是一种二进制格式,并且不序列化字段名,因此它使用的空间比等效的JSON消息少。但是存在缺点:即序列化消息不可读,并且需要 Protobuf 定义来反序列化消息,可能会影响开发人员的体验。

下面的 JSON 示例将占用大约66个字节(去掉空白)。

{\"persons\": [ {\"name\": \"Max\",\"age\": 23 }, {\"name\": \"Mike\",\"age\": 52 } ]}

等效的序列化 protobuf 消息将仅使用19个字节。

0x0A070A034D617810170A080A0448616E731034大消息

Protobuf 设计用于序列化和反序列化内存中的消息。因此,不建议使用 Protobuf/gRPC 传输巨大的消息。大多数 gRPC 实现对单个消息的默认限制为4MB。

使用 REST API 处理大数据量(例如文件上传)是相当直接的。接收到的文件可以被视为流,只需使用很少的内存。这在 gRPC 中需要更多的操作:文件必须在发送方分为几个部分。然后,每个块将作为单独的消息通过客户端流传输方法发送到服务器。服务器接收每个块,并构造数据流,从而产生与 REST API 类似的行为。

浏览器兼容性

浏览器兼容是 REST 真正的闪光点。它由 WEB 浏览器本地支持,因此可以轻松地使用 WEB应用程序中的 REST API。

gRPC 不直接由浏览器支持,因为它需要明确的 HTTP/2 支持和访问某些 HTTP/2 功能,而 WEB浏览器不提供这些功能。作为一种变通方法,可以使用 gRPC Web 协议,使其可供 WEB 浏览器使用。对于某些编程语言,框架中已经包含了gRPC Web 支持。对于其他场景,需要一个代理来将 gRPC 流转换为 gRPC Web 流,反之亦然。与不需要依赖关系的 REST API 相比,gRPC API 在 WEB 上使用更麻烦。

解决方法可以是使用 JSON 转码,这允许开发人员将 gRPC API 公开为 REST API。

工具

gRPC 和 REST 工具在编程语言和框架之间差异很大。在某些情况下,gRPC 感觉更“原生”,而在另一些情况下,REST 工具则更高级。对 gRPC 的编程语言支持更为重要,因为需要工具来生成特定编程语言的客户端和服务器存根。对于不受支持的编程语言,不建议使用 gRPC 。

由于 REST API 存在的时间要长得多,因此存在更多有助于构建、测试和部署 REST API 的工具。它们的功能通常比 gRPC 工具更高级。

小结

对于“应该使用 REST 还是 gRPC ?” 没有明确的答案。有些 API 有独特的用例,gRPC 或 REST 可能更适合这些用例。

REST 和 gRPC 都有各自的优点和缺点。

从 WEB 应用程序中使用 REST API 通常更容易。REST也得到了更广泛的使用,这使得开发人员使用它更简单。

gRPC 在服务器到服务器的通信(例如:微服务之间)方面无疑具有优势。能够共享准确的API定义并用多种编程语言创建 API 客户端,这是一个巨大的优势。

引用链接

[1] A detailed comparison of REST and gRPC: https://kreya/blog/rest-vs-grpc/[2] HATEOAS: https://enpedia/wiki/HATEOAS[3] JSON:API: https://jsonapi/[4] 编程语言列表: /d/file/gt/2023-09/wif3vjs2s1n

声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送至邮件举报,一经查实,本站将立刻删除。转载务必注明出处:http://www.hixs.net/article/20240117/1696257922101969.html