Using Protocol Buffers for implementing RPC in ZeroMQ

前端 未结 1 505
旧时难觅i
旧时难觅i 2021-02-06 16:16

I have a simple setup of one client and one server. The client wants to execute a method in the server using ZeroMQ for communications. I am going to use the REQ and REP sockets

相关标签:
1条回答
  • 2021-02-06 17:00

    Don't do it that way. Have a message:

    message InputParameters{
        req oneof
        {
            InputParametersA a = 1;
            InputParametersB b = 2;
        }
    }
    message InputParametersA
    {
        bool block = 1;
        float temperature = 2;
    }
    message InputParametersB
    {
        <more fields>
    }
    

    That way you send only the InputParameters message. The method to call is dictated by whether InputParameters.req contains an InputParametersA (implies that method A should be called), or InputParmetersB (for method B).

    This avoids parsing a string to determine a method name (highly error prone), and instead gives you an enumeration to switch on (the possible content of the req field). Depending on the implementation of GPB you're using (C++, etc) you may even get a compile time warning if your switch statement doesn't adequately cover all values of that enumeration.

    It also means that there's no problems in determining which of the fields should be passed to a method; you're passing either InputParameters.req.a into method A or .b into method B. There's no need to break them out into separate parameters for a method, simple pass the whole thing in as a single parameter.

    You can define different return types in the same way, passing them all back through a single oneof.

    Alternatives

    Now if you were using ASN.1 (which is conceptually the same kind of thing as GPB), you could set constraints on the values and / or sizes of message fields (see here, Chapter 13 in this PDF. That way you'd have parameter validation being performed automatically, defined solely in the ASN.1 schema. The lack of value / size constraints in GPB is a glaring omission.

    Take a look here (overview), here (free schema compiler for C/C++ that looks OK), and here (PDF, reference manual).

    ASN.1 has stronger typing in its wire format (if you use BER encoding). It's possible to interrogate a wire bit stream to find out what type of message it contains. Thus there is no need to resort to wrapping all your possible messages up into a single oneof like you do with GPB.

    0 讨论(0)
提交回复
热议问题