共计 2048 个字符,预计需要花费 6 分钟才能阅读完成。
本篇内容介绍了“ABAP 应用服务器的组成部分是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
一个典型的 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 服务器上。
“ABAP 应用服务器的组成部分是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!