Tuxedo入门学?

中间件介绍:

介于客户机和server之间的夹层,突破了传统的c/s架构,为构建大规模,高性能,分布式c/s应用程序提供了通信,事物,安全,容错等基础服务,屏蔽了底层应用细节,应用程序不必从底层开发,以自身的复杂性换取应用程序开发的简单。

Tuxedo是什么?

Tuxedo:Transaction for Unix has been Extended for Distributed Operation分布式操作扩展之后的Unix事务系统。

交易中间件位于client和server之间

Tuxedo是一个事务处理(TP)监督器(transaction
processing monitor),它管理联机事务处理(OLTP)系统操作的事务。客户通过结构化查询语言(SQL)调用,或其他类型的请求,产生对server的请求。这个事务处理监督器确信,正确地进行了改动,以保证数据的完整性。这在一个事务能够改变多个位置的数据库的分布式数据库环境是很重要的。这个事务处理监督器使用双阶段提交,以保证全部的数据库都已经接收和认可了这些数据的正确性。否则,这个数据库返回它的事务前状态

WTC:WebLogic
Tuxedo Connector

OLTP:
On-Line Transaction Processing 联机事务处理

OLAP:
On-Line Analytical Processing 联机分析处理

ATMI:application-to-Transaction
Monitor Interface 应用程序到事务监视器接口

DTP:Distributed
Transaction Processing分布式事务处理

MSSQ:Mutile
Server,Singal Queue

TUXEDO
採用三层结构的组件软件模型


Client
为第一逻辑层。实现用户交互和数据表示,向第二层的Server发请求,调用业务逻辑处理服务。


Server组件中间层,这些组件由TUXEDO管理,实现业务逻辑服务,接收服务请求,并返回服务结果。


第三层为资源管理器,比方像关系数据库。负责管理应用系统的数据资源

Tuxedo的核心子系统:

事务管理器 TM(Transaction Manager)

工作站 WorkStation

域 Domain

队列 Queue

队列:

s

X/Open DTP
模型:

Tuxedo
与 WebLogic
通过WTC互联:

通经常使用TUXEDO实现系统的核心业务,用WEBLOGIC做为系统扩展到web的平台,实现电子商务。由WEBLOGIC
调用
TUXEDO上的服务,须要在Tuxedo和Weblogic之间建立连接。

WTC不仅能让WEBLOGIC调用TUXEDO中的SERVICE,并且能让TUXEDO调用WEBLOGIC中的EJB。但WTC仅能实现这两个平台之间的互联。

Tuxedo与WebLogic
之间通过Domain实现互联调用,Tuxedo与Weblogic分别代表两个TDOMAIN。

使用WTC时,Tuxedo方面要配置对应的Domain配置文件(dmconfig),指明本身以及weblogic所在Domain的IP和Port。

使用WTC时Weblogic方面要做的改动是:

—在ClassPath
中,添?jamti.jar所在的路径。

—在weblogic的配置文件,bdmconfig.xml
中,添?描写叙述两个TDOMAIN的部分

在Tuxedo和weblogic
启动对应服务后,weblogic通过client端掉用对应ejb,再有该ejb调用tuxedo
service。

Tuxedo应用开发:

开发TUXEDO C/S系统的必要步骤:


环境变量设置,通常写在setenv.sh

TUXDIR:Tuxedo应用的安装路径。

TUXCONFIG:便以后的Tuxedo配置文件路径。

VIEWDIR/VIEWFILES:view文件的路径和文件名称。

LD_LIBRARY_PATH:Tuxedo应用时,须要寻找的库文件的路径。

PATH: Tuxedo特用的一些可运行文件的路径

假设涉及到Domain,还有对应的环境变量。


编码,并编译client/服务端程序。


编写/编译Tuxedo配置文件。

Tuxedo配置文件ubbconfig
描写叙述了应用配置信息。Ubbconfig文件是二进制文件,是由文本文件通过tmloadcf
命令编译而成。

Ubb
文件的内容包含例如以下的Section:

Resources:包括整个应用范围的信息。必须在配置在文件第一节,必不可少。

Machines:节包括应用有关的每一个处理器的信息。本节必须在*RESOURCES节后列出。

Groups:节包括服务组的定义。一台机器至少要定义一个服务组,每一个组仅仅要定义组名,映射组名的组号和逻辑机器名

SERVERS:包括了服务进程的信息。一个入口代表一个应用启动时载入的服务。这些信息包括服务名,命令行參数,服务环境,重新启动动等等。

SERVICES:提供了应用的特殊交易的信息,包含负载平衡(LOAD)和数据缓冲类型检查(BUFTYPE)。假设所有都是缺省值则本节能够省略。

上述每个Section中,包括众多的Option选项,详细应用时,察看Tuxedo相关文档,进行配置。


在执行时,这些配置信息被装入一段共享内存,称为(Bulletin-Board)。


TUXEDO提供一个管理进程,称为BBL(Bulletin Board Liaison),包括了一个公告牌的本地拷贝和本地server上应用的状态。


TUXEDO提供的还有一个管理进程DBBL(Distinguished Bulletin Board Liaison),用于多server配置时。DBBL与BBL协同,保证全部部分的公告牌内容的一致性。


启动服务。


測试(功能測试、压力測试)。

client/Client开发

client的任务:

获取採集运行操作应得的数据。

发起向服务端的请求并等待服务端回应。

将结果依照一定格式返回给用户

client的程序设计和实现应该分成两个部分:

用户处理过程。

Tuxedo功能部分。

开发Client涉及的API:

进程管理的API:

int tpinit(TPINIT *tpinfo)

负责将Client端连接到BB,使Client端能够进一步调用ATMI函数。

TPINIT參数是一个Tuxedo定义的结构,用以存放一些安全相关的数据(必须在tuxedo的配置文件里打开security选项)。否则,能够使用NULL。

tpinit,不能在server端中出现,否则tuxedo会产生TPEPROTO(协议错)这样一个错误。

int tpterm( )

client调用tpterm( )切断与应用的连接,结束了client的TUXEDO进程
.

编写完毕的Client代码,用buildclient
命令进行编译。

buildclient –f 
filename  -O output file

假设client端是一个workstation(本地没有Tuxedo
server),还要加上-w
选向。

Clieng与Server
之间的通讯接口:

Client通过ATMI提供的API,与Server之间进行通讯,调用Server提供的服务。

通讯主要分为两种方式:

同步方式:採用同步通讯时,Client端在向Server端发出请求后就被堵塞,等待Server端的返回。

同步通讯方式的API:

int tpcall( 
char  *svc,   char 
*idata,   long   ilen, char  
**odata,  long   *olen,  
long   flags)

Svc

调用的服务(service)名称

idata:
指向输入数据缓冲区指针。

ilen:  
输入数据的缓冲区大小。

odata:指向输出数据缓冲区指针的指针。

olen: 
输出数据缓冲区的大小的指针。

flags:
通讯控制标志。

异步方式:採用异步方式时,Client端在发出请求后,能够继续其它的任务,须要结果时,使用API去获取response队列中的结果。

异步通信方式的API

— int tpacall(char *svc, char *data, long len, long
flags)

— tpacall 调用成功后返回一个整数,称为descriptor,client使用这个整数在以后的某个时间来获取结果。

ATMI提供tpgetrply( )
来获取异步调用的结果

— int tpgetrply(int *cd, char **data, long *len, long
flags)

— 參数cd ,
就是存放tpacall返回descriptor的指针。

不管是tpcall、tpacall以及tpgetrply,在client端和server端都能够使用。

Server端开发:


Server是系统资源的联系点。


Server必须公布系统内能够訪问的交易,保证client能够知道把请求发往何处


Server启动后,进入一个循环:接收请求/处理请求/返回节后,周而复始。


系统管理员通过命令tmshutdown,显式地关掉tuxedo的服务。

Server端开发涉及的API:


tpreturn( ):
在Tuxedo中,tpreturn用来取代常规的return函数,运行tpreturn后,server将回应的数据缓冲区返回请求的发起点,交出程序的控制权。

void tpreturn(int rval, long
rcode, char *data, long len, long 
flags)

rval :是返回的结果,一般是TPSUCCESS,
TPFAIL,  TPEXIT。

  
 rcode:是用户自己定义的返回值,用以进一步区分返回结果。

 
  data 
:是返回结果缓冲区。len:是缓冲区长度。

flags : 
结果返回的标志,通常都是0。

 


tpsvrinit()和tpsvrdone()分别用来启动和关闭服务。

假设在server的代码中,不提供这两个函数,Tuxedo将使用缺省函数。

tpsvrinit()用tpopen()缺省打开RM连接。

tpsvrdone()用tpclose()关闭RM连接。

tpsvrinit()仅仅在服务boot起来时运行一次。对应的
tpsvrdone()也仅仅在服务shutdown时运行一次。

设计服务时的几点考虑:


最好不要使用收到的数据缓冲向其它服务请求,由于该缓冲可能被改变引起错误。


所有在服务中分配的数据缓冲,在程序结束时必须所有释放;唯一例外是用在tpreturn()中的返回数据缓冲。


服务中的交易不应调用本服务中的交易,由于easy产生死锁。


一个MSSQ集中的服务须要返回时,应有自己的返回队列;否则会与本集中其它服务冲突。(RQADDR
= XXXX ,同一时候REPLYQ = Y)。

缓冲区数据类型:


Client与Server之间,Server与Server之间,都要通过数据缓冲区来传递数据。


sTuxedo支持下图所看到的的缓冲区类型:


Buffer type包括:STRING,CARRY,VIEW,FML等。

STRING:是以空值结尾的单字字符串

CARRY:有长度定义的二进制数据。

VIEW: 
类似于C的structure。

FML: 
固定结构的自己定义缓冲。

Tuxedo中的事务处理


不管是Client还是Server都能够主动发起一个全局事务。


Tuxedo会对一个transaction产生一个全局交易ID(GTRID),这个ID号在全部的交易參与这样的共享,并唯一标示这个transaction。


Tuxedo通过TLOG,来跟踪一个全局交易。


提供通知(notify)RM的方法,使得RM知道自己參加到一个交易中,并lock住对应的记录。


Tuxedo作为TM,能够管理两阶段提交(two-phase
commit)。使得全部交易參与者一起提交,保持结果的一致性。

TMS和RM之间,使用XA接口来协调工作。

Tuxedo提供tpbegin, tpcommit, tpabort
等API来管理交易

Tuxedo中的事务处理:

事务管理器:

时间: 2024-10-10 00:02:56

Tuxedo入门学?的相关文章

spring mvc开发入门实例demo源代码下载,很适合新手入门学习用。

原文:spring mvc开发入门实例demo源代码下载,很适合新手入门学习用. 源代码下载:http://www.zuidaima.com/share/1550463469046784.htm Eclipse + Maven + Spring MVC - Simple Example 源代码框架截图:

tuxedo入门

为文件增加用户执行权限: 官网下载tuxedo111120_64_Linux_01_x86.bin su //进入root操作,防止权限不够 创建文件夹,用来做tuxedo文件的安装路径 mkdir /opt/tuxedo/ ls -l //查看用户执行权限会发现创建的用户对这个文件没有执行权限,然后授权chmod 755 tuxedo111120_32_Linux_01_x86.bin 可以./tuxedo111130_64_Linux_01_x86.bin直接图形化安装,下面使用命令模式进行

Tuxedo入门学习

中间件介绍: 介于客户机和server之间的夹层,突破了传统的c/s架构,为构建大规模,高性能,分布式c/s应用程序提供了通信,事物,安全,容错等基础服务,屏蔽了底层应用细节,应用程序不必从底层开发,以自身的复杂性换取应用程序开发的简单. Tuxedo是什么? Tuxedo:Transaction for Unix has been Extended for Distributed Operation分布式操作扩展之后的Unix事务系统. 交易中间件位于client和server之间 Tuxed

一篇文章让你快速入门 学懂Shell脚本

Shell脚本,就是利用Shell的命令解释的功能,对一个纯文本的文件进行解析,然后执行这些功能,也可以说Shell脚本就是一系列命令的集合. Shell可以直接使用在win/Unix/Linux上面,并且可以调用大量系统内部的功能来解释执行程序,如果熟练掌握Shell脚本,可以让我们操作计算机变得更加轻松,也会节省很多时间. Shell应用场景 Shell能做什么 将一些复杂的命令简单化(平时我们提交一次github代码可能需要很多步骤,但是可以用Shell简化成一步) 可以写一些脚本自动实现

CTF入门指南

转自http://www.cnblogs.com/christychang/p/6032532.html ctf入门指南 如何入门?如何组队? capture the flag 夺旗比赛 类型: Web密码学pwn 程序的逻辑分析,漏洞利用windows.linux.小型机等misc 杂项,隐写,数据还原,脑洞.社会工程.与信息安全相关的大数据reverse 逆向windows.linux类ppc 编程类的 国内外著名比赛 国外:国内:xctf联赛 0ctf上海国内外都有,很强 入门需要哪些基础

.NET Core系列 : 1、.NET Core 环境搭建和命令行CLI入门

2016年6月27日.NET Core & ASP.NET Core 1.0在Redhat峰会上正式发布,社区里涌现了很多文章,我也计划写个系列文章,原因是.NET Core的入门门槛相当高,很有必要写个深入浅出的系列文章,本节内容帮助你入门.我将可能用Windows做开发环境,也可能用Linux/Mac,但是所有的dotnet CLI命令都是跨平台的,我们在windows/Linux/mac平台上开发跨平台的应用. 安装.NET Core .NET Core 包括.NET Core Runti

NET Core 环境搭建和命令行CLI入门

NET Core 环境搭建和命令行CLI入门 2016年6月27日.NET Core & ASP.NET Core 1.0在Redhat峰会上正式发布,社区里涌现了很多文章,我也计划写个系列文章,原因是.NET Core的入门门槛相当高,很有必要写个深入浅出的系列文章,本节内容帮助你入门.我将可能用Windows做开发环境,也可能用Linux/Mac,但是所有的dotnet CLI命令都是跨平台的,我们在windows/Linux/mac平台上开发跨平台的应用. 安装.NET Core .NET

JAVA学到什么程度才可以转战Android?【高手解惑】

如果有同学想要深入了解或是说有什么疑问的呢可以加***流487425429. 先简单的分两种情况:一.有编程基础,或者科班出身的,直接上吧.强烈推荐郭霖老师的<第一行代码-Android>二.没编程基础的,先入门java,如果天天都有比较多的空闲时间的话,这个入门时间要在2周完成,如果没有的话,1个月内完成吧,不要让拖延耽搁你的激情.如果你准备好了进军Android:不管你什么时候开始学习Android,请使用Android Studio,首现改主题,然后去网上搜一下常用的20个快捷键截图放在

NET Core 环境搭建和命令行CLI入门[转]

NET Core 环境搭建和命令行CLI入门 时间:2016-07-06 01:48:19      阅读:258      评论:0      收藏:0      [点我收藏+] NET Core 环境搭建和命令行CLI入门 2016年6月27日.NET Core & ASP.NET Core 1.0在Redhat峰会上正式发布,社区里涌现了很多文章,我也计划写个系列文章,原因是.NET Core的入门门槛相当高,很有必要写个深入浅出的系列文章,本节内容帮助你入门.我将可能用Windows做开