github.com/linapex/ethereum-dpos-chinese@v0.0.0-20190316121959-b78b3a4a1ece/rpc/doc.go (about)

     1  
     2  //<developer>
     3  //    <name>linapex 曹一峰</name>
     4  //    <email>linapex@163.com</email>
     5  //    <wx>superexc</wx>
     6  //    <qqgroup>128148617</qqgroup>
     7  //    <url>https://jsq.ink</url>
     8  //    <role>pku engineer</role>
     9  //    <date>2019-03-16 12:09:45</date>
    10  //</624342664057196544>
    11  
    12  
    13  /*
    14  包RPC提供通过网络访问对象的导出方法的权限
    15  或其他I/O连接。创建服务器实例后,可以注册对象,
    16  使其从外部可见。遵循特定的导出方法
    17  可以远程调用约定。它还支持发布/订阅
    18  模式。
    19  
    20  满足以下条件的方法可用于远程访问:
    21   -必须导出对象
    22   -必须导出方法
    23   -方法返回0、1(响应或错误)或2(响应和错误)值
    24   —方法参数必须导出或内置类型
    25   -方法返回值必须导出或内置类型
    26  
    27  示例方法:
    28   func(s*calcservice)add(a,b int)(int,error)
    29  
    30  当返回的错误不是nil时,将忽略返回的整数,错误为
    31  发送回客户端。否则,返回的整数将发送回客户机。
    32  
    33  接受指针值作为参数支持可选参数。例如。
    34  如果我们想在一个可选的有限域中做加法,我们可以接受一个mod
    35  参数作为指针值。
    36  
    37   func(s*calservice)add(a,b int,mod*int)(int,错误)
    38  
    39  可以使用2个整数和一个空值作为第三个参数调用此rpc方法。
    40  在这种情况下,mod参数将为零。或者可以用3个整数来调用,
    41  在这种情况下,mod将指向给定的第三个参数。因为可选
    42  参数是rpc包还将接受2个整数作为
    43  争论。它将把mod参数作为nil传递给rpc方法。
    44  
    45  服务器提供了接受ServerCodec实例的servedec方法。它将
    46  从编解码器读取请求,处理请求并将响应发送回
    47  使用编解码器的客户端。服务器可以同时执行请求。响应
    48  可以按顺序发送回客户端。
    49  
    50  使用JSON编解码器的示例服务器:
    51   类型计算器服务结构
    52  
    53   func(s*计算器服务)添加(a,b int)int
    54   返回A+B
    55   }
    56  
    57   func(s*calculatorservice)div(a,b int)(int,error)
    58   如果B==0 {
    59    返回0,errors.new(“被零除”)。
    60   }
    61   返回A/B,NIL
    62   }
    63  
    64   计算器:=新建(CalculatorService)
    65   服务器:=newserver()
    66   server.registername(“计算器”,计算器)
    67  
    68   l,:=net.listenunix(“unix”,&net.unixaddr net:“unix”,name:“/tmp/calculator.sock”)
    69   对于{
    70   c,:=l.acceptUnix()。
    71   编解码器:=v2.newjsoncodec(c)
    72   go server.servedec(编解码器)
    73   }
    74  
    75  包还通过使用订阅支持发布订阅模式。
    76  被视为符合通知条件的方法必须满足以下条件:
    77   -必须导出对象
    78   -必须导出方法
    79   -第一个方法参数类型必须是Context.Context
    80   —方法参数必须导出或内置类型
    81   -方法必须返回元组订阅,错误
    82  
    83  示例方法:
    84   func(s*blockchainservice)newblock(ctx context.context)(订阅,错误)
    85    …
    86   }
    87  
    88  订阅在以下情况下被删除:
    89   -用户发送取消订阅请求
    90   -用于创建订阅的连接已关闭。这可以启动
    91     通过客户端和服务器。服务器将在发生写入错误或
    92     缓冲通知队列太大。
    93  **/
    94  
    95  package rpc
    96