这个系列的第一篇文章,我们了解了什么是SAP应用服务器实例,并使用SAPGUI这个客户端软件,成功登录到了SAP CRM系统的一个应用服务器实例AG3.

本文继续学习ABAP应用服务器的组成部分。

一个典型的ABAP应用服务器由下列组件构成:

(1) Internet Communication Manager (ICM)

(2) ABAP dispatcher

(3) Task handler

(4) 若干工作进程,类型有dialog, update, print, background等等

(5) RFC Gateway

(6) Standalone enqueue server

(7) SAP Message Server

这些组件的关联关系如下图,一个SAP系统可以包含多个应用服务器实例,但ASCS实例只能有一个。

下面简单介绍每个组件的功能。

Internet Communication Manager (ICM) - SAP NetWeaver

ICM是Netweaver服务器里一个单独的进程,由ABAP Dispatcher启动并监控,负责SAP系统和外部的网络通信。基于收到请求URL的解析,ICM会将请求分发给具体的handler进行处理。

ICM常用的与Internet交互的协议有HTTP,HTTPS,SMTP等。

下图是ICM的架构图。

Thread Control:该线程负责接收外界请求,从ICM线程池中取出空闲的工作线程,将请求的上下文交给工作线程。

工作线程:负责请求的具体处理,包含一个I/O处理器,可以用来进行网络的输入和输出操作。对于不同协议类型的请求,Thread Control会调度包含了对应协议插件的工作线程。

Watchdog:如果一个工作线程在任务处理时出现了等待某个响应直至超时的情况,Watchdog会将该工作线程释放,避免其无限期的等待,这样该工作线程可以服务于其他请求。而Watchdog会继续等待尚未到来的响应。其后如果响应到达,Watchdog会通知Thread control, 后者会继续调用新的工作线程来处理。

Signal Handler:处理来自操作系统或者其他进程的信号。

Connection Info: 这张表维护了每个连接的状态信息,包括内存管道等。

Memory Pipes:内存管道是基于内存的通讯数据结构,用于将ICM接收到的外部请求包含的数据转交给工作线程。

Internet Server Cache:服务器端的缓存,对于重复的请求可以加快响应速度。

ABAP Dispatcher和工作进程

二者的关系在下图体现得很清晰,ABAP应用服务器上运行着许多不同类型的工作进程。

SAP gateway

SAP系统之间,以及SAP系统与外部系统间通过基于TCP/IP的RFC调用进行通信,而gateway作为RFC调用分发的入口,如下图所示:

SAP Message Server

每个SAP系统只能包含一个消息服务器,该组件负责完成以下任务:

(1) 作为SAP系统内多个应用服务器实例间的通讯渠道

(2) 对来自客户端通过SAPGUI和SAP RFC登录请求的负载分发

当一个应用服务器实例启动后,其dispatcher进程就会联系消息服务器,向其报告自己能够提供的服务类型。

SAP Router

一个单独运行的程序,保护SAP系统不被未经授权的请求所访问。

SAProuter在网络连接拓扑结构中,在SAP系统间以及SAP系统和外部网络间,扮演着proxy的角色,是基于端口过滤的防火墙机制的一种补充,通常直接安装在防火墙主机上。

SAPRouter维护了一张路由权限表,可以以此维护可以允许何种类型的请求同防火墙背后的SAP系统建立连接。

SAP Start Service

该服务运行在部署了SAP应用服务器实例的服务器上,实现载体是windows的系统服务(sapstartsrv.exe)和Unix系统的Daemon进程(sapstartsrv).

SAP Start Service实现的功能有:

(1) 启动和终止SAP应用服务器实例,及其运行状态的监控

(2) 应用服务器日志,跟踪和配置文件的读取与管理

Enqueue Server

实现ABAP应用程序级别的锁管理机制。应用服务器实例上所有用户当前会话持有的锁,都维护在Enqueue服务器的锁信息管理表中,该表维护在Enqueue服务器的内存中,不会进行持久化,因此Enqueue服务器成为了ABAP系统的单点故障源之一:当Enqueue服务器由于各种原因运行时发生故障需要重启时,维护在内存中的锁信息表的数据会丢失。

因此为了确保Enqueue服务器的高可用性,通常将其放到单独的物理主机上部署,甚至引入主从机制的多台Enqueue服务器,将Master Enqueue服务器上的锁信息管理表同步到其他Enqueue服务器上。

rfc垮端口 sap_SAP扫盲系列之二:SAP ABAP应用服务器的组成部分相关推荐

  1. SAP扫盲系列之二:SAP ABAP应用服务器的组成部分

    这个系列的第一篇文章,我们了解了什么是SAP应用服务器实例,并使用SAPGUI这个客户端软件,成功登录到了SAP CRM系统的一个应用服务器实例AG3. 本文继续学习ABAP应用服务器的组成部分. 一 ...

  2. BizTalk学习笔记系列之二:实例说明如何使用BizTalk

    BizTalk学习笔记系列之二:实例说明如何使用BizTalk --.BizTalk学习笔记系列之二<?XML:NAMESPACE PREFIX = O /> Aaron.Gao,2006 ...

  3. nginx系列之二:配置文件解读

    ** 前言 ** nginx系列之一:nginx入门 nginx系列之二:配置文件解读 nginx系列之三:日志配置 nginx系列之四:web服务器 nginx系列之五: 负载均衡 nginx系列之 ...

  4. STM32F103五分钟入门系列(二)GPIO的七大寄存器+GPIOx_LCKR作用和配置

    摘自:STM32F103五分钟入门系列(二)GPIO的七大寄存器+GPIOx_LCKR作用和配置 作者:自信且爱笑' 发布时间: 2021-05-01 12:08:32 网址:https://blog ...

  5. 【转】Tomcat总体结构(Tomcat源代码阅读系列之二)

    本文是Tomcat源代码阅读系列的第二篇文章,我们在本系列的第一篇文章:在IntelliJ IDEA 和 Eclipse运行tomcat 7源代码一文中介绍了如何在intelliJ IDEA 和 Ec ...

  6. Kubernetes生产实践系列之二十二:Service Mesh之在Kubernetes部署Linkerd2进行service mesh

    一.前言 service mesh是为复杂微服务系统提供基础设施服务的方法,支持Kubernetes的service mesh实现包括文章<kubernetes系列之十八:使用helm安装ist ...

  7. Docker系列(二十三)——Docker实例五Docker安装MongoDB实例

    < Docker实例三Docker安装MongoDB实例 > 前言 在前面一篇文章种,完成了 < Docker安装MySQL实例 >,本篇将继续镜像安装教程,并完成Docker ...

  8. 防火墙系列(二)-----防火墙的主要技术之包过滤技术,状态检测技术

    防火墙系列(二)-–防火墙的主要技术 必备知识:TCP/IP基础 包过滤技术 工作对象–>数据包 防火墙要在数据包进入系统之前处理它 实现包过滤技术的防火墙模块要在操作系统协议栈的网络层的位置. ...

  9. PCIe扫盲系列博文连载目录

    转载自 http://blog.chinaaet.com/justlxy PCIe扫盲系列博文连载目录篇(第一阶段) 1.前言篇:PCIe扫盲--PCIe简介:http://blog.chinaaet ...

最新文章

  1. File.separator
  2. R语言使用scales包的hue_pal函数获取ggplot2任何级别的离散色码、使用scales包的hue_pal函数获取ggplot2任何级别的反序(reverse)离散色码
  3. 基于XMPP协议的aSmack源码分析
  4. quratz启动流程
  5. Linux 安装 配置 Maven
  6. Typecho博客支持Emoji表情功能设置
  7. VK Cup 2012 Round 1 D. Distance in Tree (树形dp)
  8. 2019的第一工作日
  9. CCF CSP202112-1 序列查询
  10. Freescale MC9S08AW60汇编学习笔记(三)
  11. 菜鸟的学习之路(6) — 设计模式之单例模式(Singleton)
  12. Android基础知识、四大组件(转)
  13. 瑞泰信息携手大族数控,打造营销服务管理平台,夯实领先地位
  14. window清理系统垃圾文件代码
  15. saas模式的外贸建站比较
  16. macOS:实现 声音内录 不用其它App
  17. Cortex-A7 MPCore 架构
  18. php html ubb,php UBB 解析实现代码
  19. 郑州大学计算机考研拟录取名单,郑州大学2017年统考硕士生拟录取名单2(17)
  20. 软件开发生命周期中的设计阶段_软件过程模型|如何进行团队式的软件开发?...

热门文章

  1. 设置系统的viewController modal动画样式
  2. 三招教你如何判断ERP软件是否适用
  3. Delphi之对象库(Object Repository)
  4. java IDE的四大金刚
  5. SSM实现大学生综合素质评测系统
  6. python – 在循环中创建不同的变量名
  7. 微信公众平台开发 微信JSSDK开发
  8. 'ModelOptions' object has no attribute 'get_field_names
  9. js选择checkbox值,组织成key-value形式,传值到后台
  10. 301重定向的好处: