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

相关文章

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Debian系和Redhat系防火墙配置方式

《Debian系和Redhat系防火墙配置方式》文章对比了Debian系UFW和Redhat系Firewalld防火墙的安装、启用禁用、端口管理、规则查看及注意事项,强调SSH端口需开放、规则持久化,... 目录Debian系UFW防火墙1. 安装2. 启用与禁用3. 基本命令4. 注意事项5. 示例配置R

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Redis MCP 安装与配置指南

《RedisMCP安装与配置指南》本文将详细介绍如何安装和配置RedisMCP,包括快速启动、源码安装、Docker安装、以及相关的配置参数和环境变量设置,感兴趣的朋友一起看看吧... 目录一、Redis MCP 简介二、安www.chinasem.cn装 Redis MCP 服务2.1 快速启动(推荐)2.

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例