wamp介绍及crossbar.io服务搭建

wamp 推送/订阅消息讲解

wamp官网:http://wamp-proto.org/

crossbar官网:https://crossbar.io/

1、wamp是什么?我们的项目中为什么要使用wamp?

webSocket:双向数据传输协议,服务器可以主动向客户端发送消息,WebSocket是基于Http协议的。

以前服务端想往客户端发送消息(两种方式)

ajax轮询

让浏览器隔个几秒就发送一次请求,询问服务器是否有新信息(需要处理速度快)。

long poll

客户端发起连接后,如果没消息,就一直不返回Response给客户端(服务挂起,阻塞了,需要多并发)。直到有消息才返回,返回完之后,客户端再次建立连接,周而复始。

wamp和websocket关系

WAMP易于使用,易于实现,并基于现代Web标准:WebSocket,JSON和URI。

WAMP是一种开放标准的WebSocket子协议,在一个统一协议中提供两种应用程序消息传递模式:

远程过程调用(RPC)+发布和订阅(Publish & Subscribe)。

WebSocket是相当低级的,只提供原始消息。 WAMP将RPC和PubSub的更高级别的消息传递模式添加到WebSocket中。

在技术上,WAMP是使用JSON作为消息序列化格式的正式注册的WebSocket子协议(运行在WebSocket之上)。

虽然具有JSON序列化的WAMP-over-WebSocket是WAMP的首选传输,但协议也可以使用MsgPack作为序列化运行,运行在原始TCP或通常基于任何基于消息的双向可靠传输。

wamp跨语言性

WAMP在使用不同语言的开放WebSocket协议中提供统一的应用程序路由。可以使用JavaScript编写前端,在浏览器中运行,可以使用Python或Java编写后端。可以相互传输数据。

问题2解决、1、服务端需要向客户端推送消息;2、wamp的跨语言性;3、wamp模型比传统模型更好

wamp模型对比:

传统模型:客户端-服务器模型

这里写图片描述

在客户端 - 服务器模型中,客户端需要知道服务端所在的位置以及如何访问它。 这引起了客户端和服务端之间的强耦合。 应用程序容易变得复杂和不可维护。

wamp模型:客户端-中间人-客户端模型;
这里写图片描述

客户端只需要知道中间人的url,也就是crossbar服务的地址,这个url始终不会改变。数据交互通过两个人定义主题实现

crossbar.io(用python写的一个router)

Crossbar.io是用于分布式和微型服务应用程序的开源网络平台。 它实现了开放的Web应用程序消息传递协议(WAMP),功能丰富,可扩展,强大而安全。 让Crossbar.io照顾消息传递的重要部分,以便您可以专注于应用程序的功能。

WAMP客户端库可用于15种语言,可以将任何东西连接到Crossbar.io。

使用Crossbar.io,您可以在同一应用程序中混合使用不同语言编写的组件。
这里写图片描述

总结:

WebSocket是基于Http协议的,wamp协议目前基于websocket协议,crossbar是对wamp协议的实现。

两种crossbar部署方式(官方)

1、docker虚拟化工具

docker是近年来新兴的虚拟化工具,它可以和虚拟机一样实现资源和系统环境的隔离

2、部署源代码(https://crossbar.io/docs/Installation-on-Linux/

(unbuntu或者debian)

//准备工作
sudo apt-get update
sudo apt-get -y dist-upgrade
sudo apt-get -y install build-essential libssl-dev libffi-dev libreadline-dev libbz2-dev libsqlite3-dev libncurses5-dev

//安装cPython
cd $HOME
wget https://www.python.org/ftp/python/2.7.13/Python-2.7.13.tar.xz
tar xvf Python-2.7.13.tar.xz
cd Python-2.7.13
./configure --prefix=$HOME/python2713
make
make install

//安装pip(安装python包的工具)
~/python2713/bin/python -m ensurepip
~/python2713/bin/python -m pip install -U pip
//使用pip安装crossbar
~/python2713/bin/pip install crossbar
//查看crossbar版本
~/python2713/bin/crossbar version

这里写图片描述

~/python2713/bin/crossbar init
之后找到,<.crossbar/config.json>配置config.json

这里写图片描述

~/python2713/bin/crossbar start --cbdir /home/.crossbar &

wamp使用(angular-wamp)

angular-wamp插件github:https://github.com/voryx/angular-wamp

//连接服务 
    app.config(function ($wampProvider) {        
      $wampProvider.init({                 
        url: 'ws://ip:port/ws',//服务端Ip            
        realm: 'realm1'//认证信息        
      });    
    });

发布-订阅
服务器可以向前端推送消息

//A订阅消息
    $wamp.subscribe('message', onevent);//订阅信息
    function onevent(data) {
      if(data){
       console.log('收到新消息',JSON.stringify(data));
       }else {
         console.log('失败');
       }
    }
//B推送消息
    setInterval(publish,1000);//推送消息
    function publish() {
       console.log('我一直在推送消息');
       $wamp.publish('message', ['Hello, world!']);
    }

远程调用rpc
A和B分别是两个服务,在A注册了add2函数,在B可以调用

    //服务端A
    $wamp.register('com.myapp.add2', add2);
    function add2(args) {
        return args[0] + args[1];
    }
//服务端B
$wamp.call('com.myapp.add2', [2, 3]).then(
            function (res) {
                $scope.add2 = res;
                console.log(res)
        });      

猜你喜欢

转载自blog.csdn.net/qq_34134278/article/details/78252766