Tuxedo Multi-Domains 配置

2023-10-11 19:32
文章标签 配置 multi domains tuxedo

本文主要是介绍Tuxedo Multi-Domains 配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介:本文适合初学tuxedo 。使用的例子也是tuxedo为我们提供的simpapp。

master   192.168.1.127   提供TOLOWER服务

backup   192.168.1.128   提供TOLOWER服务


客户端程序 simpcl.c 中tpcall调用TOLOWER 服务。
ret = tpcall("TOLOWER", (char *)sendbuf, 0, (char **)&rcvbuf, &rcvlen, (long)0);

服务端程序  simpserv.c 增加TOLOWER 函数,保证客户端能够调用。

void TOLOWER(TPSVCINFO *rqst)
{
        int i;

        for(i = 0; i < rqst->len-1; i++)
                rqst->data[i] = tolower(rqst->data[i]);

        /* Return the transformed buffer to the requestor. */
        tpreturn(TPSUCCESS, 0, rqst->data, 0L, 0);
}


一:环境

linux:centos 6.2  i386

tuxedo: Oracle Tuxedo, Version 11.1.1.2.0, 32-bit, Patch Level (none)

需要的文件:

lower 编译好的客户端调用tolower服务的程序。

toupper编译好的客户端调用toupper服务的程序

bdmconfig 编译好的二进制域配置文件


二详细操作步骤

1.设置环境变量

建议两台机子最好一样,避免出错。

TUXDIR=/home/tux/Oracle; export TUXDIR
JAVA_HOME=$TUXDIR/jre; export JAVA_HOME
JVMLIBS=$JAVA_HOME/lib/i386/server:$JAVA_HOME/jre/bin
PATH=$TUXDIR/bin:$JAVA_HOME/bin:$PATH; export PATH
COBCPY=:$TUXDIR/cobinclude; export COBCPY
COBOPT="-C ANS85 -C ALIGN=8 -C NOIBMCOMP -C TRUNC=ANSI -C OSEXT=cbl"; export COBOPT
SHLIB_PATH=$TUXDIR/lib:$JVMLIBS:$SHLIB_PATH; export SHLIB_PATH
LIBPATH=$TUXDIR/lib:$JVMLIBS:$LIBPATH; export LIBPATH
LD_LIBRARY_PATH=$TUXDIR/lib:$JVMLIBS:$LD_LIBRARY_PATH; export LD_LIBRARY_PATH
WEBJAVADIR=$TUXDIR/udataobj/webgui/java; export WEBJAVADIR
LANG=C; export LANG
APPDIR=/home/tux/simpapp; export APPDIR
TUXCONFIG=$APPDIR/tuxconfig; export TUXCONFIG
BDMCONFIG=/home/tux/simpapp/bdmconfig; export BDMCONFIG

2  .编写ubbconfig 文件

以下是master机子上的,只提供tolower服务。backup机子类似,只不过把服务改成toupper。

[tux@master simpapp]$ vi ubbsimple 
MASTER          TUX1
MAXACCESSERS    150
MAXSERVERS      120
MAXSERVICES     120
MODEL           SHM*MACHINES
DEFAULT:master          LMID=TUX1APPDIR="/home/tux/simpapp"TUXCONFIG="/home/tux/simpapp/tuxconfig"TUXDIR="/home/tux/Oracle"MAXWSCLIENTS=5*GROUPS
GROUP1          LMID=TUX1       GRPNO=1                 OPENINFO=NONE
LDMGRP          LMID=TUX1       GRPNO=20
LGWGRP          LMID=TUX1       GRPNO=30*SERVERS
DEFAULT:CLOPT="-A"simpserv        SRVGRP=GROUP1 SRVID=1
WSL             SRVGRP=GROUP1 SRVID=10CLOPT="-A -- -n //192.168.1.127:3200 -m 2 -M 5 -x 10 -p 4500 -P 5000"DMADM           SRVGRP=LDMGRP SRVID=1
GWADM           SRVGRP=LGWGRP SRVID=100
GWTDOMAIN       SRVGRP=LGWGRP SRVID=200 REPLYQ=N*SERVICES
TOLOWER

3.编写domconfig文件

master机器的配置文件:

*DM_RESOURCES
VERSION=test1*DM_LOCAL_DOMAINS
LAPP    GWGRP=LGWGRPTYPE=TDOMAINDOMAINID="LAPP"DMTLOGDEV="/home/tux/simpapp/DLOG"
*DM_REMOTE_DOMAINS
UAPP    TYPE=TDOMAINDOMAINID="UAPP"*DM_TDOMAIN
LAPP    NWADDR="//192.168.1.127:7000"
UAPP    NWADDR="//192.168.1.128:7000"*DM_REMOTE_SERVICES
TOUPPER*DM_LOCAL_SERVICES
TOLOWER

backup远端机器域配置文件如下:

*DM_RESOURCES
VERSION=Utest1*DM_LOCAL_DOMAINS
UAPP    GWGRP=UGWGRPTYPE=TDOMAINDOMAINID="UAPP"DMTLOGDEV="/home/tux/simpapp/DLOG"*DM_REMOTE_DOMAINS
LAPP     TYPE=TDOMAIN   DOMAINID="LAPP"*DM_TDOMAIN
LAPP NWADDR="//192.168.1.127:7000"
UAPP NWADDR="//192.168.1.128:7000"*DM_LOCAL_SERVICES
TOUPPER*DM_REMOTE_SERVICES
TOLOWER

4.在backup机子上执行如上1、2、3操作。只更改服务为toupper服务。

5. 编译配置文件,以及客户端和服务端程序。

buildserver -f simpserv -o simpserv -s TOUPPER -s TOLOWER   

buildclient -f simpcl.c -o lower  

tmloadcf -y ubbsimple (执行之后会生成tuxconfig二进制文件)

dmloadcf -y dmconfig(执行后会生成bdmconfig二进制文件)

6.启动tuxedo。

7.至此整个配置过程已经结束。接下来看一下tuxedo客户端调用服务。我们的客户端是不知道服务在哪台机子上的。

tolower服务在master机子上,我们可以在backup机子的客户端调用tolower服务。因为bakcup机子上的UAPP domain 中不包括这个服务,他就会调用远端机子的tolower的服务。

首先我们看 master机子的服务还没有一笔交易:

[tux@master simpapp]$ tmadmin
tmadmin - Copyright (c) 1996-2010 Oracle.
Portions * Copyright 1986-1997 RSA Data Security, Inc.
All Rights Reserved.
Distributed under license by Oracle.
Tuxedo is a registered trademark.> d -m TUX1TUX1> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      TUX1           0      0         0 (  IDLE )
DMADM          00020.00001 LDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      0         0 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 LGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 LGWGRP       200      0         0 (  IDLE )TUX1> 

在远端机子调用: 

[tux@backup simpapp]$ ./lower "HELLO WORLD"
Returned string is: hello world
[tux@backup simpapp]$

查看master机子 已经有一笔交易:这笔交易就是由远端的tuxedo客户端调用。

TUX1> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      TUX1           0      0         0 (  IDLE )
DMADM          00020.00001 LDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      1        50 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 LGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 LGWGRP       200      0         0 (  IDLE )TUX1> 

----------------------------------------------------------------------------------------------------------------------------------------

同理我们在master 机器调用调用远端机子的toupper服务

调用之前:

[tux@backup simpapp]$ tmadmin
tmadmin - Copyright (c) 1996-2010 Oracle.
Portions * Copyright 1986-1997 RSA Data Security, Inc.
All Rights Reserved.
Distributed under license by Oracle.
Tuxedo is a registered trademark.> d - m^H
TMADMIN_CAT:145: ERROR: Syntax error on command line.> d -m backupbackup> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      backup         0      0         0 (  IDLE )
DMADM          00020.00001 UDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      0         0 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 UGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 UGWGRP       200      1         0 (  IDLE )backup>

调用之后;

[tux@master simpapp]$ ./toupper zhoulei
Returned string is: ZHOULEI
[tux@master simpapp]$ 
backup> psr
Prog Name      Queue Name  Grp Name      ID RqDone Load Done Current Service
---------      ----------  --------      -- ------ --------- ---------------
BBL            123456      backup         0      0         0 (  IDLE )
DMADM          00020.00001 UDMGRP         1      7       350 (  IDLE )
simpserv       00001.00001 GROUP1         1      1        50 (  IDLE )
WSL            00001.00010 GROUP1        10      0         0 (  IDLE )
GWADM          00030.00100 UGWGRP       100      0         0 (  IDLE )
GWTDOMAIN      00030.00200 UGWGRP       200      1         0 (  IDLE )backup> 


最基本的tuxedo多域模式配置,仅供自己学习。学术不精,忘给位给予指点!


参考:

百度文库:http://wenku.baidu.com/view/edbd80a5b0717fd5360cdc4d.html

联动北方技术论坛:http://www.landingbj.com/jbbs/index.jsp

《叱咤风雨-Weblogic企业级运维实战》 清华大学出版社  戴冠平 著











这篇关于Tuxedo Multi-Domains 配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/190348

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

2014 Multi-University Training Contest 8小记

1002 计算几何 最大的速度才可能拥有无限的面积。 最大的速度的点 求凸包, 凸包上的点( 注意不是端点 ) 才拥有无限的面积 注意 :  凸包上如果有重点则不满足。 另外最大的速度为0也不行的。 int cmp(double x){if(fabs(x) < 1e-8) return 0 ;if(x > 0) return 1 ;return -1 ;}struct poin

2014 Multi-University Training Contest 7小记

1003   数学 , 先暴力再解方程。 在b进制下是个2 , 3 位数的 大概是10000进制以上 。这部分解方程 2-10000 直接暴力 typedef long long LL ;LL n ;int ok(int b){LL m = n ;int c ;while(m){c = m % b ;if(c == 3 || c == 4 || c == 5 ||

2014 Multi-University Training Contest 6小记

1003  贪心 对于111...10....000 这样的序列,  a 为1的个数,b为0的个数,易得当 x= a / (a + b) 时 f最小。 讲串分成若干段  1..10..0   ,  1..10..0 ,  要满足x非递减 。  对于 xi > xi+1  这样的合并 即可。 const int maxn = 100008 ;struct Node{int

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom