BTP Integration Suite学习笔记 - (Unit4) Developing with SAP Integration Suite

详细指导还是要看官方文档

在这里插入图片描述

4. 云集成管理

4.1 云集成介绍

什么是云集成?
前三章讲了很多内容,但都不是最核心的,通常我们用CPI是让他实现原来PI/PO的功能的,是用来做集成的。这章才刚开始。
在这里插入图片描述

云集成有以下几个特性:

  • SAP Cloud Integration通过消息交换支持端到端流程集成。
  • 它基于Apache软件基金会的开源框架Camel。
  • 它是SAP BTP集成套件的核心功能之一。
  • 开发、部署和监视在浏览器中使用图形工具进行。
  • 它是LowCode/No Code工具之一。

4.1.1 连接

在这里插入图片描述
更多信息

两端是发送方的适配器和接收方的适配器,中间是处理过程,感觉是不是和PI/PO一样了。可以处理同步和异步的消息。
发送方和接收方的适配器是不同的,哪些适配器能用取决于买的lisence。也可以自己开发适配器。
在这里插入图片描述
在这里插入图片描述

新创建一个集成,发现支持平台还有SAP PO的选项,不明白,暂时放下。
在这里插入图片描述

在这里插入图片描述

4.1.2 集成功能

在这里插入图片描述
各种工件有不同的功能。详细信息更多信息
集成流可以加入各种功能,可以自由组合,可以设计出非常复杂的集成流,这也是CPI相对PIPO更灵活的特点之一,同时这也增大了我们开发集成流的难度,所以SAP在SAP Business Accelerator Hub中做了很多预定义的集成,让我们可以参考甚至直接拿来用。这里可以选择源和目标系统。
在这里插入图片描述
比如S/4HANA和Concur
在这里插入图片描述
然后就可以进入到具体的集成流中
在这里插入图片描述
查看相关配置和文档做参考。也可以通过导出导入的方式创建自己的集成流。

举例解读一个集成流
在这里插入图片描述
大概分了8个阶段:

  1. 将带有productid的列表数据使用SOAP的方式发送到集成流。
  2. 拆分出迭代数据Product List。
  3. 调用OData API检查每个ProductID,检查它是否在数据库中可用。
  4. 判定ProductID是否存在于数据库中,如果不在直接结束。如果在走第5步。
  5. 调用HTTP API根据ProductID获取SalesOrderLineItems (SalesOrderID, ItemPosition)。
  6. 迭代SalesOrderLineItems数据。
  7. 为每个SalesOrderLineItems (SalesOrderID, ItemPosition)条目取到SalesHeader (CustomerID)。
  8. 在每个SalesHeader中,选择Customer ID并将其写入数据存储。

所以这个集成流整体实现的是根据ProductID清单找到所有对应订单中的CustomerID。其中当然还有一些数据验证。
练习

4.2 开发周期

在这里插入图片描述
这个图主要是方便理解云集成的URL,这个例子也很容易看明白:
在这里插入图片描述
开发云集成最少需要分配PI_Integration_Developer角色。

4.2.1 技术实施

CPI的核心是Apache Camel应用集成开发框架,SAP通过图形客户端和各种安全特性增强了这个Camel框架。由以下组件组成:
在这里插入图片描述
整个过程大概是:用户通过浏览器(1)Cloud Integration URL访问实现,以创建和管理集成流。第二个组件(2)是图形界面,一旦创建了集成流,如果它作为Java应用程序部署在runtime时(Cloud Foundry, Kyma)上,(4)消息可以使用发送方组件(4)传输,并使用接收方组件(4)接收。其中负载均衡器(IP5)是连接到发送方(3)的。

上面提到集成“实现”也就是一个Java应用程序部署在runtime中占用的资源是有限的,一个CPI实现占用:
在这里插入图片描述

要开发一个云集成,通常是这么几步:

  • 理解用户需求
  • 配置BTP子账户和Integration suite
  • 确认所需API,以及相关Metadata,认证,header等等
  • 开始创建空白集成模版(遵守命名规范)
  • 将流程模块快
  • iflow逐步实现集成过程
  • 测试

定期对开发状态进行版本化是很重要的,这样可以在必要时恢复到以前的版本。

在这里插入图片描述

模拟执行
模拟单个组件或整个集成流对于验证内容转换中的值是否设置正确,或者脚本或映射是否按预期执行非常有用。但并不是所有的集成流组件都支持模拟
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
模拟执行后可以查看每一步的消息详细信息:
在这里插入图片描述
在这里插入图片描述
一旦集成流完成,就对其进行版本控制和部署,从而在RUNTIME中创建和部署Java应用程序。然后可以执行这个集成流。开发过程可以作为迭代来处理,其中组件的添减和配置,使用跟踪日志级别进行调试,以及重复测试,直到达到期望的结果。

练习:创建一个package和空白iFlow

4.3 使用消息监控和日志

除了标准的内置监视器之外,还可以使用各种工具与Cloud Integration Monitoring一起使用。它提供了不同的类别,包括消息监视、内容管理和警报管理。这里只讨论用于消息的内置监视器和API日志。

4.3.1 内置消息监控器

在这里插入图片描述

消息状态:

  • Completed
  • Processing
  • Retry
  • Escalated
  • Failed
  • Canceled
  • Discarded
  • Abandoned

在这里插入图片描述
如果将日志级别设置为trace,则可以点击trace进入到流程流的调试模式

在这里插入图片描述

系统日志
System Log Files 可以查看系统日志,包括HTTPs访问日志和跟踪日志,日志保存时间为30天。
在这里插入图片描述
在这里插入图片描述

这个Monitor本身也是基于Cloud Integration的API的。
在这里插入图片描述
在这里插入图片描述

所以其它系统也是可以通过API可以调用日志的

首先需要这两个权限之一:PI_Administrator , PI_Integration_Developer

URL: https://…hana.ondemand.com:443/api/v1/LogFiles

更多信息
更多信息

4.3.2启用External logging

(只适用Cloud Foundry环境)适用的业务场景有很多,比如要使用splunk进行日志分析,或是对多个租户的日志进行收集,或是长期归档或是审计需求。

两个前提:

  1. 角色权限 AuthGroup_Admin 或是ExternalLoggingActivate
  2. 官方OData API的activateexternalloging功能

设置入站HTTP连接(用于API客户端)
其中这三个认证方式可以找机会再认真了解一下,这也是HTTP最常用的三种认证。
在这里插入图片描述
ExternalLoggingActivationReadExternalLoggingActivate

4.3.3 使用定时器事件替换开始事件

太简单,不赘述,重点是理解定时器的作用,使用定时器组件,每次部署,都可以进行触发iFlow,当然这个和scheduler的配置有关,可以选择一次性触发,也可以是周期式的触发。其中一个作用就是可以用来debug。修改后点击部署就可以触发来检查iFlow是否有问题。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

4.4 Camel数据模型和简单表达式语言

4.4.1 Camel数据模型

在这里插入图片描述
它是下面元素的容器:

  • Headers: 报头数据包含与消息相关的信息,例如消息发送者的地址,并且自动包含在任何后续的HTTP调用中
  • Properties: 在消息处理期间,可以以上下文对象的形式临时存储其他数据
  • Attachment: 要附加到消息的可选数据
  • Body: 要在消息中传输的有效负载包含在正文中。在消息处理期间,还可以使用Exchange容器,它可以存储消息之外的其他数据。此容器由Exchange ID唯一标识,可以在消息处理期间在Properties区域中保存临时数据。存储在Exchange容器中的数据在整个消息交换期间可用,并在调用下一个处理步骤时包含在容器中。
  • Others

4.4.1.1 Exchange parameters的操作

有多种方法可用于操纵交换参数:

  • 使用Content Modifier组件
  • 使用 Groovy SDK
  • 使用 JS SDK
  • 在消息映射中使用PDF
  • 使用XSLT映射
  • 使用Filter组件
  • 使用Content Enricher组件

下面逐一说明

使用Content Modifier组件

在这里插入图片描述
图形化,使用方便 ,可以用来修改:
Header
Properties
Body

更多
可以直接更改负载,只需将所需的目标值直接添加到相应的字段中。可以是任何格式,纯文本,XML, JSON等。

可以直接替代负载,也可以是用表达式动态
在这里插入图片描述
在这里插入图片描述
上面这个表达式就是把原有报文加到了其中,在原有报文基础上加了一些常量。

还可以参考现有header或是properties并用在表达式里:
在这里插入图片描述
注意Content Modifier是修改负载很强大的工具,但对于XML修改,建议使用其他流程步骤,因为在修改或合并XML有效负载时可能会使XML编码无效。
更多

使用 Groovy SDK

com.sap.gateway.ip.core.customdev.util.Message类提供了操纵参数的方法
在这里插入图片描述
例子

使用 JS SDK

同上

使用XSLT映射

另一种更改XML消息的方法是使用XSL转换,或者简而言之就是XSLT。XSLT是一种基于文本的映射脚本,它允许解析源XML并根据转换脚本生成目标XML。
在这里插入图片描述
创建XSLT转换
例子

使用Filter

如果有效负载是XML消息,并且我们只需要现有有效负载的某一部分,那么就可以使用Filter,Filter允许提供XML路径或简短的XPath。XPath的结果就被设置为新的有效负载。这也是修改负载的一种方式。
意思就是只允许符合条件的节点过去成为新负载。
在这里插入图片描述
更多
更多

使用Content Enricher组件

详细内容

4.4.2 Simple Expression Language简单表达语言

简单表达式语言用于参数化Exchange parameters。它还提供了许多内置参数,如时间戳、错误消息等。这些参数我们只有读访问权限。看到这就已经明白,它是用来操作来往负载的,想要灵活控制负载,不管是header还是parameters或是body报文,就这个语言来做控制。既然是个语言一定用它的语法和内置变量以及内置表达式或函数,用的多了自然就熟了,先从认知上了解就好。
除个修改负载还可以用来动态的控制Router,掌握了这个语言就可以很自如的控制接口。

内置参数或是交换参数一般以 ${}符号引用,在Cloud Integration中,可以将${}占位符插入到例如Content Modifier步骤中的负载中,或者在Query Editor中应用,从而向OData资源路径添加动态值。非常重要。
${}占位符还可以与运算符组合生成布尔表达式用来做逻辑判断,可以将其用作路由器、过滤器和更多集成流组件中的条件中。比如:

${property.MyNumericProperty} > 0
${property.MyStringProperty} contains ‚test‘
property.ProductCoderegex‚[a−z]5\d3‘
${date:now:dd-MM-yyyy HH:mm}

日常使用的参数有

Message Body
${in.body}
Properties
${property.}
Message Headers
${header.}

简单表达式语言可以用在:

  • 使用Groovy或JavaScript编写的脚本。
  • 在一些集成流组件(如Router、Content Modifier和Message Mapping)中作为用户定义的函数。
  • 在XSLT映射中。
  • 在一些用于查询的适配器中。

小结
Camel数据模型要结合简单表达语言来理解学习。用于管理各个集成流组件处理期间的临时数据。该数据模型不仅包括有效负载(主体),还包括属性和报头数据,它们自动包含在HTTP调用中。
每个处理步骤都将Exchange容器从前一个处理步骤传递到下一个处理步骤。交换参数可以自动设置(例如在接收消息时),也可以通过Content Modifier或Groovy SDK等组件手动设置。Camel Data Model在处理过程中管理临时数据,其中包括有效负载(主体)、属性和报头数据。报头数据自动包含在HTTP调用中。
通过简单表达式语言访问要读取的交换参数,该语言不仅包括内置参数,还允许对复杂的正则表达式进行建模。

Content modifier实例

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

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

相关文章

Django进阶:DRF(Django REST framework)

什么是DRF? DRF即Django REST framework的缩写,官网上说:Django REST framework是一个强大而灵活的工具包,用于构建Web API。 简单来说:通过DRF创建API后,就可以通过HTTP请求来获取、创建、更新或删除数据(…

【SVN内网穿透】远程访问Linux SVN服务

文章目录 前言1. Ubuntu安装SVN服务2. 修改配置文件2.1 修改svnserve.conf文件2.2 修改passwd文件2.3 修改authz文件 3. 启动svn服务4. 内网穿透4.1 安装cpolar内网穿透4.2 创建隧道映射本地端口 5. 测试公网访问6. 配置固定公网TCP端口地址6.1 保留一个固定的公网TCP端口地址6…

SpringBoot整合阿里云OSS,实现图片上传

在项目中&#xff0c;将图片等文件资源上传到阿里云的OSS&#xff0c;减少服务器压力。 项目中导入阿里云的SDK <dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.10.2</version>…

在ubuntu+cpolar+rabbitMQ环境下,实现mq服务端远程访问

文章目录 前言1.安装erlang 语言2.安装rabbitMQ3. 内网穿透3.1 安装cpolar内网穿透(支持一键自动安装脚本)3.2 创建HTTP隧道 4. 公网远程连接5.固定公网TCP地址5.1 保留一个固定的公网TCP端口地址5.2 配置固定公网TCP端口地址 前言 RabbitMQ是一个在 AMQP(高级消息队列协议)基…

开源的密码学工具库:openssl安装在docker容器环境Linux(ubuntu18.04)

OpenSSL&#xff08;Open Secure Socket Layer&#xff09;是一个开源的密码学工具库&#xff0c;它提供了一系列的加密、解密、认证和通信安全相关的功能。OpenSSL 最初是为了支持安全的网络通信而设计的&#xff0c;但后来它的功能逐渐扩展到了许多不同的领域&#xff0c;包括…

多核异构核间通信Mailbox vs rpmsg

目录 一、关键术语解释 二、Mailbox与rpmsg对比 三、rpmsg传输流程 异构核间数据通过共享内存实现数据传递&#xff0c;通过中断来触发发送、接收。 一、关键术语解释 IPC Inter-Processor Communication MailBox IP which provides queued interrupt mechanism for comm…

javaWeb第一课

前言&#xff1a; 先来说说本来写完了的聊天室的项目&#xff0c;然后后面凡尔赛不小心改错了的然后一个上午才发现的问题&#xff0c;真的很有必要总结一下&#xff0c;气死我了&#xff1a;关于要将这个ArrayList的某个类型要转换为数组&#xff0c;我刚开始这么写的&#x…

leetcode 118.杨辉三角

⭐️ 题目描述 &#x1f31f; leetcode链接&#xff1a;https://leetcode.cn/problems/pascals-triangle/description/ 代码&#xff1a; class Solution { public:vector<vector<int>> generate(int numRows) {// 先开空间vector<vector<int>> v;v.…

【数据结构】C语言实现栈(详细解读)

前言: &#x1f4a5;&#x1f388;个人主页:​​​​​​Dream_Chaser&#xff5e; &#x1f388;&#x1f4a5; ✨✨专栏:http://t.csdn.cn/oXkBa ⛳⛳本篇内容:c语言数据结构--C语言实现栈 目录 什么是栈 栈的概念及结构 实现栈的方式 链表的优缺点: 顺序表的优缺点: 栈…

AI创作助手:介绍 TensorFlow 的基本概念和使用场景

目录 背景 环境测试 入门示例 背景 TensorFlow 是一个强大的开源框架&#xff0c;用于实现深度学习和人工智能模型。它最初由 Google 开发&#xff0c;现在已经成为广泛使用的机器学习框架之一。 TensorFlow 简单来说就是一个用于创建和运行机器学习模型的库。它的核心概念…

2023年骨传导耳机推荐,一文读懂骨传导运动耳机哪个牌子好!

这几年&#xff0c;耳机圈开始流行起骨传导耳机&#xff0c;这种耳机通过贴合耳道附近的颌骨通过振动传递声音到听觉神经&#xff0c;相比较入耳式耳机来说&#xff0c;更有利于耳道卫生&#xff0c;而且在听歌同时可保持对环境声的感知&#xff0c;深受不少运动达人的喜爱。我…

LVS之keepalived

1、keepalived 概述 总结&#xff1a;Keepalived 软件就是通过VRRP协议来实现高可用功能。 应用场景&#xff1a;企业应用中&#xff0c;单台服务器承担应用存在单点故障的危险 单点故障一旦发生&#xff0c;企业服务将发生中断&#xff0c;造成极大的危害 VRRP通信原理&…

【Rust】Rust学习 第十六章无畏并发

安全且高效的处理并发编程是 Rust 的另一个主要目标。并发编程&#xff08;Concurrent programming&#xff09;&#xff0c;代表程序的不同部分相互独立的执行&#xff0c;而 并行编程&#xff08;parallel programming&#xff09;代表程序不同部分于同时执行&#xff0c;这两…

iOS逆向初探:揭开iOS App的神秘面纱

逆向是一种分析和还原应用程序的过程&#xff0c;它能够揭示应用程序内部的工作原理和代码结构。接下来我们将全面介绍iOS上的逆向&#xff0c;包括其概念、常用工具和具体实例。 1. 什么是iOS逆向&#xff1f; iOS平台逆向是将应用程序的二进制代码&#xff08;通常是经过编…

使用PyMuPDF添加PDF水印

使用Python添加PDF水印的博客文章。 C:\pythoncode\new\pdfwatermark.py 使用Python在PDF中添加水印 在日常工作中&#xff0c;我们经常需要对PDF文件进行处理。其中一项常见的需求是向PDF文件添加水印&#xff0c;以保护文件的版权或标识文件的来源。本文将介绍如何使用Py…

反向传播求变量导数

反向传播求变量导数 1. 相关习题2. 推导流程2.1 相关公式2.3 变量导数求解 3. 代码实现3.1 参数对应3.2 代码实现 以前只知道反向传播通过链式法则实现今天看书发现图片上求出来的值自己算不出来所以自己算了一下&#xff0c;记录一下&#xff0c;并运行了书中的代码相关书籍&a…

第一讲使用IDEA创建Java工程——HelloWorld

一、前言导读 为了能够让初学者更快上手Java,不会像其他书籍或者视频一样,介绍一大堆历史背景,默认大家已经知道Java这么编程语言了。本专栏只会讲解干货,直接从HelloWord入手,慢慢由浅入深,讲个各个知识点,这些知识点也是目前工作中项目使用的,而不是讲一些老的知识点…

java学习004

常用数据结构对应 php中常用的数据结构是Array数组&#xff0c;相对的在java开发中常用的数据结构是ArrayList和HashMap&#xff0c;它们可以看成是array的拆分&#xff0c;一种简单的对应关系为 PHPJAVAArray: array(1,2,3)ArrayListlArray: array(“name” > “jack”,“…

OpenEuler华为欧拉系统安装

OpenEuler华为欧拉系统安装 一、OpenEuler简介1、OpenEuler概述2、OpenEuler特性 二、OpenEuler部署安装1、安装前配置2、安装引导3、选择语言4、安装信息摘要 三、欧拉系统安装图形化界面1、需要在超级管理员&#xff0c;在root权限下操作2、启动图形化界面 四、手动安装VMwar…

系统报错mfc100u.dll丢失的解决方法(完美解决dll问题)

系统文件mfc100u.dll丢失和出错&#xff0c;极有可能是盗号木马、流氓软件等恶意程序所导致&#xff0c;其感染相关文件并加载起来&#xff0c;一旦杀毒软件删除被感染的文件&#xff0c;就会导致相关组件缺失&#xff0c;游戏等常用软件运行不起来&#xff0c;且提示“无法启动…