zoukankan      html  css  js  c++  java
  • 实现WebSocket和WAMP协议的开源库WampSharp

    Websocket Application Messaging Protocol 协议:https://github.com/wamp-proto/wamp-proto 

    1. 基础档案

    引入:

    WAMP协议是一种建立在Websocket之上可以进行publish&subscribe和rpc的通信协议。它实现了类似ZeroMQ中的pub&sub通信模式,同时将这种模式用于传统的rpc通信,较好地解耦了通信端点之间的直接联系。

    基础概念:

    broker:pub&sub通信模式中的中间件。

    dealer:rpc中caller&callee通信的中间件。

    router:router其实就是broker和dealer的结合体。

    realm:realm为router中的一个活动空间,client之间通信以realm为活动区间。

    client:通信实体,消息发布者/订阅者,接口调用者/实现者。

    peer:client或者router。

    role:peer所扮演的角色。

    topic:pub&sub主题,使用uri格式表达。

    procedure:rpc的接口地址,同样使用uri格式来表达。

    通信模型:

    (specification的这幅图说明了一切)

    5361433.png

    https://github.com/Code-Sharp/WampSharp 实现了 The WebSocket ProtocolThe WebSocket Application Messaging Protocol (WAMP) 协议。

    特性:

    • 支持WebSocket RFC6455和WAMP V1/v2
    • 很好的符合标准
    • 高性能异步设计
    • 易于使用的API
    Client端

    Components 的概念,就是组件,是RPC 的调用和被调用方,也可以是 PubSub的发布和订阅方,四种角色都是组件,在这个前提下写应用code。

    RPC模型

    3个角色 Caller, Callee, Dealer

    • Caller(调用者) 使用url和参数调用远程接口, Callee拿到参数去执行,然后返回结果
    • Callee 首先会注册调用到 DealerCaller的调用首先到 Dealer, Dealer 会把 Caller 的调用路由到对应的 Callee,然后把Callee的结果,返回给Caller.
    • CallerCallee 会跑应用代码,Dealer 会做RPC的通用路由。

    RPC模型主要有个两个步骤,注册程序,调用程序。

    现在问题是,我写好了RPC的程序,怎么注册到router里面呢?是在WampSharp中自动生成,还是要手动改配置文件等?

    其实都不是,都是由 Components自己去注册,其他Componets来自己使用。具体的操作类似 Callee程序连接 crossbar, 然后注册自己能给别人提供的API,然后Caller 连接 Router crossbario 调用程序,如果 Callee 掉线了,那么 Caller 也就无法调用了。

    PubSub 模型

    有3个角色 Publisher, Subscriber, Broker

    Publiser(发布者)提供 url和对应的 payload, Subscribers 订阅者可以接收到发布者的信息。Broker就是提供发布和订阅的场所。跟我们大多数的消息队列中提供的发布订阅模式类似.

    总结:

    WAMP引入的router可以使得后端接口无缝更新,另外realm使得后端接口只暴露功能子集给前端。pub&sub也可以很方便地进行消息多播。

  • 相关阅读:
    ngInclude与script加载模板
    ng-model-options
    angular模板加载 ----ng-template
    ngBind ngBindTemplate ngBindHtml
    ng-switch
    ng-show与ng-if区别
    运维教给我什么
    路漫漫其修远兮,吾将上下而求索
    那些让我们继续坚持下去句子
    随手记
  • 原文地址:https://www.cnblogs.com/shanyou/p/8053091.html
Copyright © 2011-2022 走看看