AUTOSAR_EXP_ARAComAPI的7章笔记(3)

☞返回总目录

相关总结:AutoSar AP简单多绑定总结

7.3 多绑定

如在 5.4.3 小节中简要讨论的,某个代理类 / 骨架类的不同实例之间的技术传输是不同的,多绑定描述了这种情况的解决方案。多种技术原因都可能导致这种情况出现:

  • 代理类使用不同的传输 / IPC 与不同的骨架进行通信。
  • 同样地,对于同一个骨架实例的不同代理实例,也可能使用不同的传输 / IPC 与这个骨架实例进行通信,即骨架实例支持多种传输机制的连接。

7.3.1 简单多绑定的用例

下图描绘了一个简单多绑定的用例。例子中,服务消费者和服务提供者在同一个节点(ECU 内部)中进行通信,服务消费者拥有同一个代理类的两个实例。图中可以看出,服务消费者首先触发了一个 “FindService”,它为搜索到的两个不同服务实例返回了两个句柄。服务消费者为每个句柄实例化了一个代理实例。在这个例子中,服务实例 1 与服务消费者(代理实例 1)位于同一个 AP 应用程序(相同的进程 / 地址空间)中,而服务实例 2 与服务消费者(代理实例 2)位于不同的 AP 应用程序(不同的进程 / 地址空间)中。

图 7.3 中,象征代理和骨架之间传输层的线条颜色不同:代理实例 1 有一个红色的传输层(绑定实现),而代理实例 2 的传输层是蓝色的。颜色不同是因为在代理实现层面上使用的技术不同。如果想努力打造一个性能良好的产品,AP 产品供应商(作为 IPC 绑定实现者的角色)需要这样做!

如图所示,因为代理实例 1 和骨架实例 1 包含在一个进程中,代理实例 1 和服务实例 1 之间的通信(红色)应该优化为一个简单的方法调用。因为代理实例 2 和服务实例 2 之间的通信(蓝色)是真正的 IPC,所以采取的行动成本要高得多,很可能涉及各种系统调用 (涉及到内核上下文切换),以便将调用 / 数据从服务消费者的进程传输到服务提供者的进程(通常使用像管道、套接字或共享内存这样的基本技术,并加上一些用于控制信号)。

从服务消费者开发者角度来看,供应商的 ProxyClass::FindService 实现为两个服务实例获得两个不透明的句柄,从这两个句柄中创建了同一个代理类的两个代理实例。“神奇地” 是,这两个代理实例虽然基于相同的代理类而创建,但是与各自的服务实例连接方式完全不同。所以,句柄中一定以某种方式包含了一些信息,代理类实例从这些信息中知道选择哪种技术传输。虽然乍一看很简单,但再看就不是了…… 问题是:是谁,在什么时候,把这些信息写入句柄中,使得从它创建的代理实例知道应该使用直接方法(函数调用),而不使用更复杂的 IPC 机制,或者反之亦然?

服务实例 1 通过 SkeletonClass::OfferService 在注册表(服务发现)中注册自己的时候吗?这取决于稍后使用它的服务消费者,所以很可能, AP 供应商的 SkeletonClass::OfferService 实现是从骨架的参数中获取所需信息,并通过特定的 IPC 通知 AP 供应商的注册表(服务发现)实现。前面句子中提及许多 “AP 供应商” 是有意的,只是表明,这里讨论的机制都没有标准化,因此可以由 AP 供应商设计和优化。然而,基本步骤将保持不变。所以通常在 SkeletonClass::OfferService 过程中从服务实例传递到注册表(服务发现)的是技术寻址信息,即如何通过本地 IPC 实现连接该服务实例。

通常在一个 AP 节点内部只会使用一种 IPC 机制!如果 AP 供应商在 AP 应用程序之间已经拥有一个优化的本地 IPC 实现,那么 AP 节点内部通常都会使用这个实现。所以 —— 在例子中,假设底层的 IPC 机制是 Unix 域套接字 —— 骨架实例 1 将创建一个套接字连接的文件描述符,并在 OfferService 期间将这个描述符传递给注册表(服务发现)。骨架实例 2 也是如此,只是描述符不同。当服务消费者执行 FindService 时,注册表将把两个服务实例的寻址信息发送给服务消费者(它们作为两个可见的不透明句柄)。

所以在这个例子中,这些句柄看起来完全相同 —— 只有一个小区别,即包含的文件描述符不同,因为它们引用不同的 Unix 域套接字。所以在这种情况下,在代理实例 1 中必须以某种方式检测到直接方法(比如:函数调用)的优化。一种可能的简单技巧是,在骨架实例 1 提供给注册表(服务发现)的寻址信息中,也包含进程的 ID(pid);要么显式地包含,要么将其包含在套接字描述符文件名中。所以服务消费者一侧的代理实例 1 可以简单地检查句柄中的 PID 是否表示与自身相同的进程,然后可以使用优化路径。顺便提一下:检测进程本地优化潜力是一件很平常的事情,几乎每个现有的中间件实现今天都在做 —— 所以无需进一步强调这个话题。

退一步的讲,我们必须认识到,这里的简单例子并没有完全反映多绑定的含义。它确实描述了同一个代理类的两个实例使用不同的传输层来联系服务实例的情况,但正如例子所示,这并没有反映在不同实例的句柄中,而仅仅是一种优化!在我们的具体例子中,使用代理实例 1 与服务实例 1 通信的服务消费者也可以像代理实例 2 一样使用 Unix 域套接字传输,而不会有任何功能损失 —— 只是从非功能性能的角度来看,这显然不好。尽管如此,这个简单的场景还是值得在这里提及,因为它是一个真实的场景,很可能在许多部署中发生,因此必须得到很好的支持!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一键生成本地SSL证书:打造HTTPS安全环境

一键生成本地SSL证书:打造HTTPS安全环境 日光下的寒林没有一丝杂质,空气里的冰冷仿佛来自故乡遥远的北国,带着一些相思,还有细微几至不可辨认的骆驼的铃声。–《心美,一切皆美》 在本地开发环境中启用 HTTPS 一直是许多…

mysql 配置文件 my.cnf 增加 lower_case_table_names = 1 服务启动不了的原因

原因:在MySQL8.0之后的版本,只允许在数据库初始化时指定,之后不允许修改了 mysql 配置文件 my.cnf 增加 lower_case_table_names 1 服务启动不了 报错信息:Job for mysqld.service failed because the control process exited …

Zookeeper的安装与使用

一、简介 1.1、概念 ZooKeeper 是一个开源的分布式协调服务,主要用于解决分布式系统中的数据一致性问题。它提供了一种可靠的机制来管理和协调分布式系统的各个节点。ZooKeeper 的设计目标是简化分布式应用的开发,提供简单易用的接口和高性能、高稳定性…

Vue3.js - 一文看懂Vuex

1. 前言 Vuex 是 Vue.js 的官方状态管理库,用于在 Vue 应用中管理组件之间共享的状态。Vuex 适用于中大型应用,它将组件的共享状态集中管理,可以避免组件间传递 props 或事件的复杂性。 2. 核心概念 我们可以将Vuex想象为一个大型的Vue&…

图论-代码随想录刷题记录[JAVA]

文章目录 前言Floyd 算法dijkstra(朴素版)最小生成树之primkruskal算法 前言 新手小白记录第一次刷代码随想录 1.自用 抽取精简的解题思路 方便复盘 2.代码尽量多加注释 3.记录踩坑 4.边刷边记录,更有成就感! 5.解题思路绝大部分来…

《Python网络安全项目实战》项目5 编写网站扫描程序

《Python网络安全项目实战》项目5 编写网站扫描程序 项目目标:任务5.1 暴力破解网站目录和文件位置任务描述任务分析任务实施相关知识任务评价 任务5.2 制作网页JPG爬虫任务分析任务实施相关知识任务评价任务拓展 WEB网站安全渗透测试过程中需要进行目录扫描和网站爬…

时序论文20|ICLR20 可解释时间序列预测N-BEATS

论文标题:N-BEATS N EURAL BASIS EXPANSION ANALYSIS FOR INTERPRETABLE TIME SERIES FORECASTING 论文链接:https://arxiv.org/pdf/1905.10437.pdf 前言 为什么时间序列可解释很重要?时间序列的可解释性是确保模型预测结果可靠、透明且易…

硬件工程师之电子元器件—二极管(4)之热量对二极管温度特性的影响

写在前面 本系列文章主要讲解二极管的相关知识,希望能帮助更多的同学认识和了解二极管。 若有相关问题,欢迎评论沟通,共同进步。(*^▽^*) 二极管 7. 热量对二极管温度特性的影响 半导体器件的电气特性通常对环境温度和工作结温敏感。 Si二极管的特性在工作范围内通常如下…

Java算法OJ(7)随机快速排序

目录 1.前言 2.正文 1. 快速排序的基本原理 2. 随机快速排序的改进 3. 随机快速排序的步骤 3.小结 1.前言 哈喽大家好吖,今儿给大家带来算法—随机快速排序相关知识点,废话不多说让我们开始。 2.正文 在了解随机快排之前,先了解一下…

基于 Python Django 的二手房间可视化系统分析

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…

用MVVM设计模式提升WPF开发体验:分层架构与绑定实例解析

MVVM(Model-View-ViewModel)是一种架构模式,广泛应用于现代前端开发,尤其是在微软的WPF(Windows Presentation Foundation)应用程序中。它旨在通过将视图(UI)与业务逻辑(…

如何进行产线高阶能耗数据的计算和可视化?

一、前言 在当前经济下行时期,越来越来多企业开始对产线进行数字化转型,提高企业竞争力。在产线数字化转型过程中,产线高阶能耗数据的计算和可视化是比较重要的一环,今天小编就和大家分享如何对产线能耗数据进行计算和可视化。 …

亲测有效:Maven3.8.1使用Tomcat8插件启动项目

我本地maven的settings.xml文件中的配置&#xff1a; <mirror><id>aliyunmaven</id><mirrorOf>central</mirrorOf><name>阿里云公共仓库</name><url>https://maven.aliyun.com/repository/public</url> </mirror>…

开源项目推荐——OpenDroneMap无人机影像数据处理

实景三维作为GIS最火的课题&#xff0c;最近在想做一套自己的三维构建工具&#xff0c;考察了几个开源项目&#xff0c;把自己的搜索过程用csdn记录下来&#xff0c;希望也能帮助到各位同仁。 OpenDroneMap&#xff08;ODM&#xff09;是一个开源项目&#xff0c;旨在处理无人…

蓝桥杯c++算法学习【2】之搜索与查找(九宫格、穿越雷区、迷宫与陷阱、扫地机器人:::非常典型的必刷例题!!!)

别忘了请点个赞收藏关注支持一下博主喵&#xff01;&#xff01;&#xff01; 关注博主&#xff0c;更多蓝桥杯nice题目静待更新:) 搜索与查找 一、九宫格 【问题描述】 小明最近在教邻居家的小朋友小学奥数&#xff0c;而最近正好讲述到了三阶幻方这个部分&#xff0c;三 …

Nuxt.js 应用中的 schema:beforeWrite 事件钩子详解

title: Nuxt.js 应用中的 schema:beforeWrite 事件钩子详解 date: 2024/11/14 updated: 2024/11/14 author: cmdragon excerpt: schema:beforeWrite 钩子是 Vite 提供的一个功能强大的生命周期钩子,允许开发者在 JSON Schema 被写入之前执行自定义操作。利用这个钩子,您可以…

当你想要conda安装遇到UnavailableInvalidChannel: HTTP 404 NOT FOUND for channel的问题

想要装个虚拟环境&#xff0c;结果遇到404。 看了第一个GitHub帖子中的一句话 UnavailableInvalidChannel: The channel is not accessible or is invalid. Navigator not launching. Issue #9473 conda/conda GitHub 想说那我就把这个not found的channel删掉吧&#xff…

DAY112代码审计PHP开发框架POP链利用Yii反序列化POP利用链

一、pop1链的跟踪 1、路由关系 2、漏洞触发口unserialize(base64_decode($data)); 2、__destruct()&#xff0c;魔术法方法调用close函数方法 3、未找到利用链&#xff0c;尝试__call魔术方法 4、逆推找call_user_func 函数 第一部分 namespace yii\db; class BatchQueryResu…

C++STL容器——map和set

目录 一.关联式容器 二.键值对 三.树形结构的关联式容器 1.set 2.map 3.multiset和multimap 四.整体代码 map_set.cpp 一.关联式容器 在初阶阶段&#xff0c;我们已经接触过STL中的部分容器&#xff0c;比如&#xff1a;vector、list、deque、 forward_list(C11)等&…

Java 责任链模式 减少 if else 实战案例

一、场景介绍 假设有这么一个朝廷&#xff0c;它有 县-->府-->省-->朝廷&#xff0c;四级行政机构。 这四级行政机构的关系如下表&#xff1a; 1、县-->府-->省-->朝廷&#xff1a;有些地方有完整的四级行政机构。 2、县-->府-->朝廷&#xff1a;直…