• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            server端ATMI

            Posted on 2008-12-11 15:48 Prayer 閱讀(1391) 評(píng)論(0)  編輯 收藏 引用 所屬分類: TUXEDO
            索引:
            1.TPSVCINFO
            2.buffer管理
            3.server的client角色
            4.tpadvertise
            5.tpunadvertise
            6.tpreturn
            7.tpforward
            8.
            tpsvrinit/tpsvrdone

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

            在server端tuxedo本身提供了一個(gè)標(biāo)準(zhǔn)的main()函數(shù),它負(fù)責(zé)完成一些必要的工作。server端編程只需要編寫service處理函數(shù),進(jìn)行service的請(qǐng)求處理和回應(yīng)處理。所以,在server端不需要調(diào)用tpinit()和tpterm()。


            1.TPSVCINFO
            每個(gè)service函數(shù)都有統(tǒng)一的形式:
            void tpservice (TPSVCINFO *svcinfo);

            只有一個(gè)參數(shù),該參數(shù)是指向TPSVCINFO結(jié)構(gòu)的指針(atmi.h)。該結(jié)構(gòu)定義如下:
            struct tpsvcinfo {
              char name[32]; /*service名(最大15個(gè)字符)*/
              long flags; /* client調(diào)用時(shí)指定的flags */
              char *data; /* 接收的數(shù)據(jù)地址 */
              long len; /* 數(shù)據(jù)長度 */
              int cd; /* 會(huì)話方式下的連接描述符 */
              long appkey; /* 應(yīng)用認(rèn)證的key */
              CLIENTID cltid; /* client ID */
            };


            --------------------------------------------------------------------------------
            2.buffer管理
            在service函數(shù)里,一樣可以調(diào)用tpalloc()、tpfree()、tprealloc()處理自定義的buffer。

            通過TPSVCINFO參數(shù)傳遞的buffer是使用tpalloc()分配的,所以可以對(duì)它使用tprealloc()。

            要注意的是在service函數(shù)里自己調(diào)用tpalloc()分配的空間在退出要釋放,除非該空間作為tpreturn()或tpforward()的參數(shù)。如果分配的空間不釋放,最終會(huì)耗盡該server的內(nèi)存資源。

            對(duì)于TPSVCINFO傳遞的buffer不用手動(dòng)釋放。

            使用舉例:
            void
            BAL (TPSVCINFO* input)
            {
              char* f, f1, f2;
              f=input->data;
              f1=tpalloc (“STRING”, NULL, 80);
              f2=tpalloc (“STRING”, NULL, 120);
              . . .
              tpfree ((char *) f2);
              tpreturn (TPSUCCESS, 0, f1, 0, 0);
            }
            可以使用tptypes()查看buffer的類型。如:
            void ABAL(TPSVCINFO *transb)
            {
              char type[20], subtype[20];
              long len;
              len = tptypes(transb->data, type, subtype);
              if (len == 0) {
                /*error*/
                userlog(“NULL message sent...\n”);
                ...
              }
              if (strcmp(type, “FML”) == 0) {
                /* convert FML to aud VIEW; */
              } else if (strcmp(type, “VIEW”) == 0) {
                if (strcmp(subtype, “aud”) != 0) {
                    /*error*/
                    userlog(“Wrong VIEW subtype...”);
                    ...
                }
              } else {
                /*error*/
                userlog(“Invalid buffer type ...”);
                ...
              }
            }


            --------------------------------------------------------------------------------
            3.server的client角色
            tuxedo的機(jī)制允許一個(gè)server程序作為client,調(diào)用tpcall()去請(qǐng)求別的service服務(wù)。這樣做可以避免代碼的冗余,但效率上會(huì)有犧牲。

            這樣做時(shí)有一些情況要注意:

            如果一個(gè)server要把負(fù)責(zé)返回接收到的buffer,則不要使用這個(gè)buffer作為參數(shù)來請(qǐng)求別的service服務(wù)。可以分配輔助性的buffer來處理,這樣做可以避免在tpcall()過程中改變了輸入buffer的內(nèi)容和類型。
            一個(gè)server不能請(qǐng)求一個(gè)只被它本身發(fā)布的service。這樣做會(huì)導(dǎo)致死鎖。例外是請(qǐng)求時(shí)指定TPNOREPLY標(biāo)志。

            --------------------------------------------------------------------------------
            4.tpadvertise
            service可以在啟動(dòng)時(shí)發(fā)布,也可使用tmadmin或使用tpadvertise動(dòng)態(tài)發(fā)布。

            int tpadvertise (char *svcname, void (*func)(TPSVCINFO *));

            參數(shù)說明:
            svcname:要發(fā)布的service名;
            func:該service對(duì)應(yīng)的處理函數(shù)指針;


            如果該service用func已經(jīng)發(fā)布,則函數(shù)立即成功返回。如果調(diào)用server是MSSQ集的一員,則該MQSQ中的所有server都發(fā)布這個(gè)service。失敗時(shí)返回-1。

            出錯(cuò)原因:

            該service已經(jīng)用別的函數(shù)發(fā)布了;
            超過了最大允許發(fā)布的service數(shù)量(MAXSERVICES);
            參數(shù)錯(cuò)誤(有為NULL的);
            協(xié)議錯(cuò);
            操作系統(tǒng)錯(cuò)等。

            --------------------------------------------------------------------------------
            5.tpunadvertise
            一個(gè)server取消發(fā)布一個(gè)它已經(jīng)發(fā)布的service。

            int tpunadvertise (char *svcname);

            參數(shù)說明:
            svcname:操作的service名;


            如果調(diào)用server是MSSQ集的一員,則該MQSQ中的所有server都取消發(fā)布這個(gè)service。失敗時(shí)返回-1。

            失敗原因:

            service沒有發(fā)布;
            參數(shù)錯(cuò)誤;
            協(xié)議錯(cuò)等。

            --------------------------------------------------------------------------------
            6.tpreturn
            普通的C函數(shù)返回時(shí)使用return語句。但在tuxedo程序里,不能使用return,必須使用tpreturn()終止當(dāng)前處理并發(fā)送回應(yīng)給請(qǐng)求端;或者使用tpforward()把請(qǐng)求傳遞給別的service處理。

            void tpreturn(int rval, int rcode, char *data,long len, long flags);

            參數(shù)說明:
            rval:返回值,決定該service請(qǐng)求是否成功。如三個(gè)可選值:


            TPSUCCESS:成功。tpcall和tpgetrply將返回一個(gè)非負(fù)值;如果是會(huì)話service,則產(chǎn)生TPEV_SVCSUCC事件;
            TPFAIL:失敗。tpcall和tpgetrply將返回-1;tperrno設(shè)置為TPESVCFAIL,如果是會(huì)話service,則產(chǎn)生TPEV_SVCFAIL事件;
            TPEXIT:除了TPFAIL的功能外,該server隨后將終止,如果配置了重啟動(dòng),則該server將重新啟動(dòng)。
            rcode:應(yīng)用定義的返回碼。service將向client返回該數(shù)字,tuxedo本身不對(duì)其做任何解釋,接收端通過全局變量tpurcode得到該值,在成功或失敗時(shí)該值都會(huì)返回;
            data:返回給client端的數(shù)據(jù)buffer;
            len:返回?cái)?shù)據(jù)的長度(只CARRAY類型有用);
            flags:標(biāo)志,當(dāng)前沒用。

            --------------------------------------------------------------------------------
            7.tpforward
            調(diào)用tpforward的server不向client返回?cái)?shù)據(jù),而是把更新過的buffer傳遞給另一個(gè)service做更多的處理,由它處理返回client數(shù)據(jù)等后續(xù)的工作。本身則返回到標(biāo)準(zhǔn)的main流程中。

            void tpforward(char *service, char *data, long len, long flags);

            參數(shù)說明:
            service:后續(xù)的service的名稱;
            data:指向傳遞的buffer的指針;
            len:buffer的長度(只CARRAY有用);
            flags:當(dāng)前沒有使用;


            該函數(shù)不能用在會(huì)話service中。

            --------------------------------------------------------------------------------
            8.tpsvrinit/tpsvrdone
            在一個(gè)server的實(shí)例啟動(dòng)時(shí)會(huì)調(diào)用tpsvrinit(),在結(jié)束時(shí)會(huì)調(diào)用tpsvrdown()。如果應(yīng)用沒有定義這兩個(gè)函數(shù),則使用tuxedo提供的缺省函數(shù)。

            int tpsvrinit(int argc, char **argv);

            參數(shù)說明:形式類似與main函數(shù)的參數(shù),函數(shù)里可以使用getopt和全局變量optind進(jìn)行處理,配置文件中的CLOPT命令行選項(xiàng)也傳遞到該函數(shù)。

            函數(shù)成功返回0,失敗返回-1。

            void tpsvrdone();
            狠狠色伊人久久精品综合网| 精品免费久久久久国产一区| 日韩中文久久| 99久久精品国产一区二区三区| 色综合久久久久综合体桃花网| 日产久久强奸免费的看| 久久人人爽人人精品视频| 国产精品成人无码久久久久久| yellow中文字幕久久网| 狠狠色伊人久久精品综合网| 久久人人超碰精品CAOPOREN| 精品免费久久久久国产一区| 午夜精品久久久内射近拍高清| 久久精品这里只有精99品| 国产精品中文久久久久久久| 久久精品国产亚洲av麻豆蜜芽 | 无遮挡粉嫩小泬久久久久久久| 久久精品国产亚洲AV不卡| 久久久久精品国产亚洲AV无码| 久久久久人妻一区二区三区| 亚洲精品无码久久久久去q | 狠狠色狠狠色综合久久| 亚洲国产精品无码成人片久久| 国产午夜福利精品久久2021| 伊人久久免费视频| 久久久久久久精品妇女99| 2020最新久久久视精品爱| 偷偷做久久久久网站| 97精品久久天干天天天按摩| 久久久精品久久久久久| 亚洲午夜久久久久久久久久| 久久久久中文字幕| 三级三级久久三级久久| 久久精品国产亚洲欧美| 99久久综合国产精品免费| 国产亚洲欧美成人久久片| 国产69精品久久久久观看软件| 久久国产一区二区| 99精品久久久久久久婷婷| 精品久久久久久久久久久久久久久| 久久精品国产亚洲av麻豆蜜芽|