Tuxedo 汇总

===================================
C/S / Tuxedo 架构/ B/S 架构演进
===================================
Tuxedo 推广使用之前, 典型的程序是C/S两层架构, 两层架构的缺点有:
1. client端直连数据库, 因为数据库会为每个连接分配一定的内存, 所以C/S架构中的client数量不能太多, 所以只适合中小型系统.
2. client端不仅仅作为UI展现端, 而且包含了绝大多数的业务逻辑(还有一小部分业务是通过数据库存储过程实现的), 这个方式的缺点是, 调整业务逻辑的代价会很大, 很难做到发布client新版本后, 所有机器都能及时升级到最新版本.

Tuxedo 引入了三层架构概念, 能很好地解决上面C/S架构的缺点, 同时又提供分布式事务控制机制, 所以在大型企业中比较流行. 新的三层架构为: client/ap server/DB, Tuxedo 作为中间件为ap server提供底层功能:
1. client端弱化为UI端, 不再包含大量的业务逻辑.
2. ap server端, 将业务逻辑集中封装到ap server端, 集中了业务逻辑, 将来调整业务的代价会小一些.
3. tuxedo 同时提供了XA分布式事务控制功能, 为关键业务提供了严密的数据一致性, 当然也有代价, 数据库执行效率下降了很多. 事务控制应该是在ap server端编程控制, 不是在client端.

上面第2/3点对于大型企业很有吸引力, 所以在2000~2010年之间Tuxedo非常受欢迎. 现在 Tuxedo 架构已经不太流行了, B/S架构和SOA和微服务早已盖过了 Tuxedo 光芒, SOA/微服务暂且不提, 这里对比一下B/S架构和Tuxedo 应用架构, 仅仅个人理解, 有些说法可能不太准确.
1. Tuxedo 应用架构中的client通常还是指GUI客户端, 虽然这里的GUI客户端没包含业务逻辑, 简单的调整业务逻辑情形可能不需要升级客户端, 但很多情况下, 调整业务逻辑都要调整UI, 这时还是需要升级客户端, 还是很麻烦. B/S架构没有这个问题.
2. Tuxedo 应用架构中的client和ap server的数据交互, 是通过 Tuxedo API完成的, 发指令之类的调用很简单, 但对于返回记录集这样的复杂类型, 编码量应该不少, 现在的B/S架构中, 浏览器和服务器是以json格式数据来相互通讯的, javascript 能非常自然地处理json, 另外, Spring web框架天然支持json序列化/反序列化, 所以数据交互这块不用额外写代码.
3. Tuxedo 提供了 XA 分布式事务支持, Spring 社区的 Atomikos 也提供这样的功能. 另外分布式事务性能很差, 所以都是谨慎使用,这样 Tuxedo 优势不明显了.

===================================
制作好的 VM 和 Docker 镜像
===================================
制作好的VirtualBox VM:
http://littles.name/tuxedodemos/TuxedoSamplesVM
http://littles.name/tuxedodemos/TuxedoSamplesVM/README
该VM账号密码:
root/samplesvm
tuxtest/tuxtest
oracle/oracle

Docker file:
https://github.com/oracle/docker-images/tree/master/OracleTuxedo

官方没有编译好的 docker 镜像, 下面是几个非官方的docker镜像
https://hub.docker.com/r/brunotaboada/tuxedo12c
https://hub.docker.com/r/bluezd/tuxedoshm
https://hub.docker.com/r/shearer9/tuxedo

===================================
相关术语:
===================================
TSAM Plus: Tuxedo System and Applications Monitor Plus, 转为监控端到端的事务和服务而设计, 可以监控 Tuxedo 基础架构的利用率, 调查活动程序的性能和行为.
Jolt: Java online transaction, 基于java的 Tuxedo 接口, https://docs.oracle.com/cd/E13161_01/tuxedo/docs10gr3/jdg/dvintro.html
SALT: Service Architecture Leveraging Tuxedo , 提供双向的、高性能、易使用的、配置驱动的模型, 它使用Http的SOAP将Tuxedo服务作为标准Web服务
ART: Application runtime, 专门面向大型机
ATMI: Application-to-Transaction-Monitor Interface, Tuxedo服务器开放给客户端的底层接口, 地位和 Oracle 数据库的 OCI 类似.
SCA: 和 ATMI 类似, 它是另一种开发模型.
WTC: Weblogic Tuxedo Connector, 通过事务和安全性传播, 提供双向/点对点的互操作性, 却博爱数据的完整性.
DTP: Distributed Transaction Processing
MIB: Management Information Base, 它是 ATMI 之下的一层, 提供 ACL 等管理方面的功能.

===================================
应用程序集成
===================================
几种集成方案:
1. 直接使用 ATMI 接口. 支持任意语言, 包括Java/.Net/Python等等.
2. [收费]WTC是 weblogic 连接tuxedo的专有方案, 但须于weblogic绑定. 仅支持 Java 集成.
3. [收费]Jolt 是tuxedo本身携带的组件, 不需要和 weblogic 绑定. Jolt 需要购买 license. 支持java或.Net集成.
4. [收费]使用SALT提供SOAP和Restful接口. 支持任意语言, 包括Java/.Net/Python等等.
5. .Net workstation client, 为.net提供的集成方式
6. activex 技术
7. wtuxws32.dll 适用于 VB/VC 等

==================================
ATMI 接口
==================================
翻译-java 客户端调用 Tuxedo中间件
https://blog.csdn.net/most_rabbitfishes/article/details/70311805

官方文档
https://docs.oracle.com/cd/E35855_01/tuxedo/docs12c/pgj/index.html


【译】使用Java编写Oracle Tuxedo应用
https://segmentfault.com/a/1190000002598827


ATMI 的功能示意:
https://docs.oracle.com/cd/E12531_01/tuxedo100/int/intatm.html

Tuxedo sample(包括虚拟机和java/python)
https://github.com/TuxedoUsers/Tuxedo-samples

tomcat集成 tuxedo
https://blogs.oracle.com/tuxedo/tomcat-and-tuxedo-perfect-together

==================================
JOLT
==================================
中间件Tuxedo调用方式
https://baijiahao.baidu.com/s?id=1566721417042476&wfr=spider&for=pc
https://my.oschina.net/gccr/blog/112405
https://my.oschina.net/hunterli/blog/12535

==================================
概述和入门
==================================
tuxedo-使用小结(写的很好,转了)
https://blog.csdn.net/u011445855/article/details/78274222/
tuxedo 简易培训教程
https://wenku.baidu.com/view/b4f6ab4e852458fb770b5627.html
Tuxedo 介绍与安装(一)
http://www.cnblogs.com/fnng/archive/2013/02/10/2909860.html
tuxedo 入门
http://blog.sina.com.cn/s/blog_6d038a250100mhqj.html
tuxedo 入门
http://blog.51cto.com/3402313/1298411
Tuxedo入门学习
https://www.cnblogs.com/mengfanrong/p/3984513.html
tuxedo 事务控制
https://www.waitig.com/tuxedo.html
Tuxedo Transaction Model(官方文档)
https://wenku.baidu.com/view/052ec035b90d6c85ec3ac641.html

猜你喜欢

转载自www.cnblogs.com/harrychinese/p/Tuxedo.html