第八章:TUXEDO的通讯方式.docVIP

  • 53
  • 0
  • 约2.91万字
  • 约 36页
  • 2017-06-22 发布于河南
  • 举报
第八章:TUXEDO的通讯方式

第八章:TUXEDO的通讯方式 TUXEDO中的客户端与服务端之间可以采用的通讯方式有: 同步调用方式 异步调用方式 管道方式 会话方式 消息方式 事件发布订阅方式 /Q方式 注意: 服务端的SERVICE之间,可以采用管道方式,客户端与服务端之间不能采用。 客户端与服务端之间可以采用消息方式,服务端的SERVICE之间不能采用消息方式。 其他通讯方式在服务端的SERVICE之间,及客户端与服务端之间都可以采用。 管道方式(tpforward())在服务端编程中有说明,/Q方式在第十章中在介绍,对这两种方式在本章种不做介绍. 8.1同步调用方式 如下图所示:在同步请求/回答方式中,客户端使用tpcall()给本地或远程的服务器(由TUXEDO系统根据公告板信息确定)发送服务请求,此时客户将传送请求服务的名字、用于请求服务的输入参数和输出参数,tpcall()发出后,客户的数据被传送至服务器,得到相应的服务处理。在此方式下,服务器处理请求时,客户端将等待,不继续运行,直到服务器返回相应结果。调用过程如图: 例子:客户端通过对一个文件分块,每调用一次TPCALL()发送一块数据,把一个文件从客户端传送到服务端。客户端与服务端采用FML32缓冲区进行通行。在异步调用方式和会话方式中也用到该例子。可以做一个比较。在该例子中我们把块的大小定义为 1024字节。采用FML32缓冲区。 FML32定义文件Myfml.h的内容: *base 100 #name number type flags comments FNAME 1 string - - BNUM 3 long BID 4 long - - FDATA 5 carray - - BSIZE 6 long - - 服务端程序Call.c的内容: #include stdio.h #include ctype.h #include atmi.h #include userlog.h #include fml32.h #include myfml.h CALL(TPSVCINFO *rqst) { FILE *fp; long i=0; FBFR32 *rcvbuf; char fname[100]=; FLDLEN32 len=0; long bid=0; long bsize=1024;/*传送的块大小为1024字节*/ char *fdata; rcvbuf=(FBFR32 *)rqst-data; len=sizeof(bid); if(Fget32(rcvbuf,BID,0,(char *)bid,len) == -1) { userlog(Fget32(BID) failure :%s,(char *)Fstrerror32(Ferror32)); tpreturn(TPFAIL,0,0,0,0); } len=sizeof(fname); if(Fget32(rcvbuf,FNAME,0,fname,len) == -1) { userlog(Fget32(FNAME) failure :%s,(char *)Fstrerror32(Ferror32)); tpreturn(TPFAIL,0,0,0,0); } strcat(fname,.s); if ((fp=fopen(fname, rb))==NULL) { fp=fopen(fname, wb); } else if(bid == 0 ) { fclose(fp); fp=fopen(fname, wb); } else { fclose(fp); fp = fopen(fname, r+b); } if(fp == NULL) { userlog(fopen() %s failure\n,fname); tpreturn(TPFAIL,0,0,0,0); } fdata=(char *)malloc(bsize+1); if(fdata == NULL) { userlog(malloc(fdata) failure); tpreturn(TPFAIL,0,0,0,0); } len=bsize; if(Fget32(rcvbuf,FDATA,0,fdata,(FLDLEN32 *)len) == -1) { userlog(Fget32(FDATA) failure :%s,(char *)Fstrerror32(Ferror

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档