最近总结了关于tuxedo编译方面的资料,以求与大家共享。。。

发布于 2022-08-24 18:20:09 字数 5718 浏览 7 评论 1

=====================================单独关于========编译=============================================================

编译服务器
      -----------------------------
      TUXEDO提供了buildserver命令来编译服务器进程。(事实上buildserver只完成预编译,它会调用当前操作系统中已经安装的默认C编译器来完成进一步的编译
      和连接,最终生成可执行代码。)
      
       buildserver[-s {@filename|service[,service...]:[:func]|:func}][-v][-o outfile]
                  [-f firstfiles][-l lastfiles][{-r|-g}rmname][-k][-t]

        ** -v  表示打开VERBOSE模式,即编译过程中打印更多的信息。

        ** -t  表示支持多线程。如果要使服务器支持多线程,则必须加上这个选项。
  
        ** -k  表示保留中间生成的带有main()函数的源程序文件,这个文件通常以"BS-"开头。如果不加-k,生成可执行代码后,这个中间文件会被自动删除。

        ** -o  outfile  指定生成的可执行文件名。

        ** -f  firstfiles   指定要优先于TUXEDO系统库之前连接的文件名。则文件名之间应以空格分隔,并用引号把整个串引起来(如-f "f1.c f2.c f3.c"),
               也可以对每个文件使用一个-f选项 (如:-f f1.c -f f2.c -f f3.c)。

        ** -l  lastfiles   指定要在TUXEDO系统库之后连接的文件名,用法同-f.

        ** -r  rmname 指定一个RM文件中定义的入口名,buildserver指示编译程序静态连接与rmname相关的库文件。

        ** -s  定义服务与函数的映射关系。通常情况下,一个服务与一个同名的函数一一对应。比如,simpserv中的TOUPPER服务就对应于TOUPPER函数。
               如果一个服务器实现了多个服(如X、Y和Z),则在编译时,既可以用一个-s来指定(如 -s X,Y,Z),也可以用多个-s来指定(如 -s X -s Y -s Z)。
               事实上,一个函数也可以实现多个服务,服务函数可以根据接收参数TPSVCINFO中的name字段来判断定户机调用了哪一个服务,然后再执行相应
               的业务逻辑。比如,函数ALL实现了X,Y和Z的业务逻辑,则在编译时,-s选项应该指定为-s X,Y,Z:ALL,逗号前后不能有空格。在某些情色况下,
               只有在运行时才知道服务,而在编译时服务名是未知的,在编译这样的服务器时,应该在函数名前面加一个冒号(如 -s:TOUPPER),在运行时,管
               理可以使用tmadmin子命令来公告服务(如 adv -g GROUP1 -i l TOUPPER:TOUPPER,冒号前面是服务名,后面是函数名)。

             如:
             buildserver -o simpserv -f simpserv.c -s TOUPPER
           
      补充:
      另如:
      使用TUXEDO的别名功能,使交易以不同名字发布,如:
      buildserver –f read.c –o read –s READ70,READ80,READ90:READ

      编译客户端
     -------------------------------------
      TUXEDO提供了buildclient命令来编译C语言客户机进程。
      
        buildclient 命令的使用方法如下:
          buildclient [-v][{-r rmname |-w}][-o name][-f firstfiles] [-l lastfiles]
           
           ** -v    打开VERBOSE模式,即编译过程中打印更多的信息。

           ** -r    rmname 与 buildserver的同名选项功能一致,即用于指定与客户程序相关的资源管理器。rmname是RM文件的一个入口,若客户程序与任何RM
                    都没有关系,可不指定这个选项。-r不能与-w一起使用,也就是说,-r只适用于本地客户机,因为远程客户机上没有RM文件。

           ** -w     指示编译器连接工作站库,而不是本地库。连接了工作站库的客户机可以通过TCP/IP访问远程TUXEDO服务器,而连接了本地库的客户机只能
                     通过共享内存连接本地TUXEDO服务器。

           ** -o     name 指定生成的目标文件名。如果不指定,在UNIX会下生成a.out。

           ** -f     firstfile 指定要优先于TUXEDO系统库之前连接的文件名。如果有多个文件,则文件名之间应以空格分隔,并用引号把整个串引起来(如 -f
                     "f1.c f2.c f3.c"),也可以对每个文件使用一个-f选项(如 -f f1.c -f f2.c -f f3.c)
           ** -l     lastfiles 指定要在TUXEDO系统库之后连接的文件名。

       如:buildclient -o simpcl -f simpcl.c

     编译加载配置文件
     ---------------------------------------------
     ASCII形式的配置文件不能直接被TUXEDO系统识别,需要使用tmloadcf命令把它转换成二进制形式才。
      
     tmloadcf命令格式如下:
     
      tmloadcf[-n][-y][-c][-b blocks][UBBCONFIG_file]

       **   -n   只对配置文件做语法检查,不做转换。

       **   -y   在确认是否初始公或覆盖二进制配置文件时,响应YES.

       **   -c   打印在当前配置下,所需要的最小的IPC资源数量。

       **   -b   如果二进制配置文件还没有初始化,-b用于指定它的最大尺寸。

     在执行tmloadcf之前,要确保已经设置了TUXCONFIG环境变量,因为它指定了生成的二进制配置文件的名字和存放的位置。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

妄想挽回 2022-08-27 13:03:47

:emn1:

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文