- 1、本文档共12页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第5章-主机的交易管理
大型主机应用上的开放系统和中间件 第5章 主机的交易管理 客户信息控制系统(CICS,全称Customer Information Control System)是IBM的通用的在线交易处理(OLTP)软件,被许多组织使用来完成交易处理需求。 一个交易是一系列的数据库更新,这些更新必须作为一个单个单元操作执行。组成交易的所有更新要么全部成功完成,要么任何一个更新都没有完成。 在交易处理过程中,用户在终端键盘上输入一个称为交易的短的请求。于是CICS应用程序立刻处理该请求并在终端屏幕上显示反馈信息。 CICS提供了并发的交易处理能力,使得在不同地理位置的许多用户可以同时输入和处理交易。 在CICS环境中,所有的用户都共享应用程序和数据文件。如果一个用户的交易更新了一个数据文件,结果将立刻反映到所有其他用户中。 在用户1更新了CICS中的一个文件后,其他用户可以通过CICS请求这个更新的文件。 CICS无缝地整合了OLTP应用需要的所有基础软件服务,从而提供了一个业务应用服务器来满足许多组织的信息处理需求。 一些CICS应用程序的样例包括:自动取款机、在线银行、保险处理系统、股票经纪系统、订单输入和处理系统、零售分销系统、薪酬系统、航班预订系统等等。 CICS为每一种类型的应用完成如下功能: 管理从并发用户来的请求。 控制对所有应用程序数据文件的访问和更新。如果一个用户的请求更新了数据库,更新的信息将立刻反映到所有用户中。 使得每一个用户看上去好像是唯一与应用程序交互的用户。 对于操作系统来说,CICS是一个通常运行在操作系统TCB上的地址空间。 对于OLTP应用程序,CICS是一个为应用程序管理系统资源的小型操作系统,这些系统资源包括:文件、数据库连接、数据库条目、程序、映像集、交易等等。 应用程序通过CICS API访问系统资源。 CICS创建一个任务来处理交易,该交易由用户通过输入交易ID到系统中而发起。CICS任务是用户交易的内部表现形式。 在CICS中,有可能多个用户在同时输入相同的交易ID。CICS创建一个唯一的任务来代表每一个交易。因此,在任何时间多个任务可能会准备着并等待执行。 在任务的生命周期中,有三个主要阶段: 准备执行 执行中 等待 当交易ID进入系统,CICS创建一个任务来处理之。该任务现在准备着执行,这是任务生命周期的第一个阶段。 虽然多个任务都可能准备着执行,同一时间只能有一个任务实际得到执行。CICS决定哪一个在准备的任务作为下一个执行,并且分派该任务来执行。在任务执行时,该任务将控制CPU。 执行是任务生命周期的第二个阶段。当任务得到调度而执行时,CICS程序开始处理,指定的交易ID得到控制权。 在某些时间点,可能在任务分派后不久,该程序可能想要CICS提供一个其代表的服务。该服务的一些样例包括将控制权传递给另一个程序,或者处理一个终端或文件I/O操作。 当服务提供起来时,在等待请求的服务完成时该任务被中断。这是任务生命周期的最后一个阶段:等待。 当被中断的任务等待服务完成时,CICS分派正准备执行的另一个任务。当一个任务在等待时,第二个任务可以执行。这就是CICS如何实现并发。 同样的,当由第二个任务激活的程序调用CICS来提供一个服务时,该任务放弃CPU的控制权并且进入到等待阶段。同时,CICS分派另一个准备执行的任务。 当然,如果CICS应用程序设计良好的话,该等待时间通常不会被用户所察觉。看起来每个用户是独自与应用程序交互的人。 当CICS通知一个被中断的任务请求服务已经完成,该任务再次进入准备执行的阶段。 这个循环会延续,直到由任务激活的程序发出一个RETURN命令将控制返回给CICS。这使得CICS终止该任务。任务终止意味着CICS释放了跟该任务相关的控制块,该任务最终离开了CICS系统。 交易处理循环的步骤总结如下: 交易ID进入CICS系统。 CICS创建一个准备执行的任务。多个任务可以同时处于该阶段。 CICS分派应当下一个执行的任务。 任务执行。它激活一个程序并将控制权传递给它。 任务调用CICS来执行一个其代表的服务,如终端或I/O操作。 任务等待其他服务完成。当第一个任务在等待时,另一个任务被分派。 服务完成,CICS任务重新分派来执行。 程序发出RETURN命令,然后CICS终止该任务。 CICS中可以运行超过一个的任务,其中一些可以处于活动队列中。然而,在任何时间只有一个任务可以得到CICS的服务。或者更准确地说,CICS将控制权传递给一个任务,并且当CICS API调用由任务发出时重新得到控制,这称为协同式多任务。与抢占式多任务不同,后者一个表现异常任务可能会阻塞CICS(不要和多线程混淆)。CICS TS和Windows 3.1属于前者,OS/390,Windo
文档评论(0)