【从零开始一步步学习VSOA开发】同步RPC客户端

同步RPC客户端

概念

前面的测试例程都是以异步 RPC 的模式运行的,客户端调用 RPC 请求后无需等待服务端应答即可返回,后面通过回回调方式获取返回结果。

同步 RPC 即客户端在发送完毕请求后,函数进入阻塞模式一直等待,直到接受到服务端应答才唤醒并退出该函数,然后通过另外接口获取执行结果。

同步 RPC 前首先需要使用 vsoa_client_sync_create 创建 RPC 同步器,其次使用 vsoa_client_sync_call 进行同步的 RPC 调用,调用结束后,再用vsoa_parser_get_payload 获取服务端返回结果,最后用 vsoa_client_sync_delete 删除 RPC 同步器。
说明:

  • 一个 RPC 同步器在同一时刻只能执行一个 RPC 同步调用。
  • 多线程同时使用同一个 RPC 同步器是不允许的。
  • 建议为每一个线程创建一个同步器,线程内调用的所有同步命令都可以使用本线程的同步器。

程序源码

基于源客户端程序修改如下:

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/select.h>
#include "vsoa_client.h"
#include "vsoa_cliauto.h"

#define MY_SERVER_PASSWD                    "123456"

static  int  sync_rpc(vsoa_client_t *client)
{
    vsoa_client_sync_call_t *sync = NULL;

    vsoa_url_t url;
    vsoa_payload_t send;
    bool ret;
    vsoa_header_t *vsoa_hdr;
    vsoa_payload_t payload;

    url.url     = "/echo";
    url.url_len = strlen(url.url);
    send.data = "1234567";
    send.data_len = strlen(send.data);
    send.param = "abcdefg";
    send.param_len = strlen(send.param);

    sync = vsoa_client_sync_create(true);
    ret = vsoa_client_sync_call(client, VSOA_CLIENT_RPC_METHOD_GET, &url, &send, sync, &vsoa_hdr, NULL);
    if (ret) {
       if (vsoa_hdr) {
           vsoa_parser_get_payload(vsoa_hdr, &payload);
           printf("echo message, param:%.*s, data:%.*s\n",
                  (int)payload.param_len, payload.param,
                  (int)payload.data_len, (char *)payload.data);
       }
    }

    vsoa_client_sync_delete(sync);

    return  (0);
}

int main (int argc, char **argv)
{
    vsoa_client_t *client;
    vsoa_client_auto_t *cliauto;

    /*
     * 创建客户端机器人
     */
    cliauto = vsoa_client_auto_create(NULL, NULL);
    /*
     * 由客户端机器人获取客户端对象
     */
    client  = vsoa_client_auto_handle(cliauto);

    /*
     * 启动客户端机器人
     */
    vsoa_client_auto_start(cliauto, "vsoa://echo_server", MY_SERVER_PASSWD, NULL, 0, 1000, 1000, 1000);

    while (true) {
        /*
         * 检查客户端是否正常链接到服务端
         */
        if (vsoa_client_is_connect(client) == false) {
            continue;
        }
        /*
         * 注册同步RPC请求
         */
        sync_rpc(client);

        sleep(1);
    }
}

执行结果

使用同步 RPC 客户端程序替换原程序重复进行 echo 试验,结果如下:

服务端执行情况:

客户端执行情况:

相关推荐
stm32 菜鸟1 小时前
nucleo-f411re学习记录-9,双轴XY摇杆传感器
学习
南子北游1 小时前
Python学习(基础语法1)
开发语言·python·学习
白晨并不是很能熬夜3 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
Atri厨3 小时前
X86存储器的段描述符学习随笔
学习
星幻元宇VR3 小时前
VR航空航天科普设备助力航天知识普及
人工智能·科技·学习·安全·vr·虚拟现实
d111111111d3 小时前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
寒秋花开曾相惜3 小时前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
叶子野格4 小时前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio
光影少年4 小时前
前端线上屏幕出现卡顿如何排查?
开发语言·前端·javascript·学习·前端框架·node.js
aacd27195 小时前
C语言之预处理详解ヾ(•ω•`)o
c语言·学习