zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    Java 猜字谜游戏
    Java中private、protected、public和default的区别
    Java JRT
    Java 数组
    javascript中的bind()方法
    2018-07-31 javascript中对的apply,call
    2018年7月31日
    【转载】javascript回调函数
    函数return以及lodash中的extend,each,map方法
    css实现动态相对居中
  • 原文地址:https://www.cnblogs.com/harrychinese/p/Tuxedo.html
Copyright © 2011-2022 走看看