Tuxedo相关原理

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Tuxedo学习

WSL workstation litener

WSH 处理请求的进程,但不server进程,相当于oracle影子进程

WSC 处理请求的进程

WS用户和正常用户的关关健差别在WS用户不装tuxedo

Abstract: 关于中间件,有一个很有名的定义是:平台+通信。这一点在TUXEDO上面得到了很好的体现,因为它提供了运行和开发的平台,以及多种的通信方式。在这多种通信方式中,使用最频繁的是WS (workstation)方式。WS方式使用的是TCP连接,为了对WS方式有更多的了解,我们结合TCP连接的知识对这种方式进行了一个比较深入的分析。

名词说明:

WSC: WorkStation Client WSL: WorkStation Listener

WSH: WorkStation Handler Server: 小写表示服务器端的服务处理进程

TCP连接是一种C/S模式的,即server端公开自己的IP和端口号,client通过这两个参数与之建立连接,客户端使用的端口一般是OS临时分配的。

TCP server端一般有两种模式,一种是iterative(重复)的,一种concurrent(并发)的。前面一种是一个server 的进程(应用层)来处理client的请求,处理完了之后继续接受请求来处理,当server正在处理的过程中,新来的请求得不到处理,只有等待。后面一种是请求到来的时候,server 进程通常会新开一个进程来处理这个请求,自己继续监听公开端口的连接请求。

在TUXEO这种事务处理系统中,会经常有大量的请求,故第一种模式肯定是不行的,第二种模式虽然可以达到同时处理不同请求的目的,但是由于每次要开新的进程,系统的开销很大,也会影响性能。实际中,TUXEDO的Workstation方式采用了另一种方法来实现多请求的并发处理。下面我们进行详细的说明。

以下是ubb中关于WSL的配置参数:

WSL SRVGRP=Group1 SRVID=200

CLOPT="-A -t -- -n //ip(服务器IP,在此隐去):4050 -m 2 -M 10 -x 10"

其中ip:4050就是TUXEDO服务器的WSL的监听地址,只有一个WSL进程。-m参数指定的是启动时WSH 的个数,-M为最大个数(用户数大于m*x时系统会自动启动更多的WSH),-x为每个WSH可以多道处理请求的最大数目,可以理解为WSH的请求缓冲区可以存放十个请求。这样我们上面的配置在启动后可以处理同时20个并发请求,最大可以处理100个。

根据这个配置和相关参数的解释,我们就可以知道TUXEDO采用的处理模式了,TUXEDO在上面TCP的第二种方式之上进行了改进。监听进程还是只有一个(WSL),但是事先已经起了多个处理请求的进程(WSH),每个WSH又可以处理多个请求,这样就保证了大量的请求能同时得到处理,也省去了临时开服务进程的开销。

为了很好的理解整个工作过程,我们首先来看一下WSC连上来的时候的一些步骤。

图1:WSC连接的工作示意图(摘自TUXEDO文档:ADCF04-WS)

上图很清晰的说明了连接的过程。

这里还需要理解是WSH和server进程之间的关系。因为大家知道,真正处理client请求的是server进程,所有的业务处理,以及和数据库相关的操作都是在server进程中完成的,这也是我们TUXEDO应用开发主要做的部分。我的理解是WSH可以看成是WSC在本地的一个代理。WSH收到WSC的请求数据,放在缓冲区,然后发给server进程来处理,因为在同一台机器上,一般采用本地进程间通信的机制,效率比较高。Server处理完后将结果返回给WSH,WSH再将结果返回给WSC,这个过程中WSH和WSC是保持着TCP 连接的,而server进程并不直接和WSC打交道。

以上的过程也可以参考下图:

图2:WS方式的连接步骤和相关模块说明图

需要解释的是WSH和server之间的粗线箭头。因为WSH和server直接是多对多的关系,每个WSH可以把请求发给多个server,每个server也可以接受多个WSH发来的请求。

还有一个问题就是TCP应用是和机器的物理端口绑定的,既然WSL和WSH都要和WSC进行TCP通信,而且很可能是同时的,那么就必须使用不同的端口。这个我们在后面会进行相关的说明。为了简便起见,我将server和WSC都实现在同一台机器上,因为是WS方式,同样会进行TCP连接,和两台机器之前的情况是一样的,但是数据流会采用回环(loopback)设备,但不影响我们对问题的说明。

结合上面的WSL设置,我们在Windows的任务管理器中看到一个WSL进程和两个WSH进程。

下面我们结合TCP的知识来说明WS方式中的连接动作。为便于数据的说明,这里给出一个TCP状态的变迁图。限于篇幅,这里不作解释,请大家参考相关的书籍。

图3:TCP状态变迁图

下面是在Windows command窗口用netstat看到的输出,并给出相关的解释说明。

图4:netstat输出1,关于WSC和WSL连接

输出的前面两行是处在TIME_WAIT状态的连接,是之前试验留下的连接,要等到两个MSL(Maximum Segment Lifetime)的时间后结束。

第三个是当前WSC到WSL的连接,这里地址显示的主机名和端口号。由于WSC和WSL的连接建立时间极短,我们没能看到WSC和WSL连接的ESTABLISHED状态,看到的是进入FIN_WAIT_2状态(从WSC 角度)和CLOSE_WAIT状态(从WSL角度)的连接。这个状态表明WSC发起了active close,发送了FIN并收到ACK,但是还没有收到WSL的FIN结束请求,连接处于half-close状态。CLOSE_WAIT表示WSL

收到WSC的FIN请求,并发回ACK,与上面的WSC的FIN_WAIT_2状态正好对应。

在上图的第二个netstat输出中,我们就可以看到使用端口号1544的WSC连接进入到TIME_WAIT状态了,

相关文档
最新文档