码迷,mamicode.com
首页 > 其他好文 > 详细

记录Ocelot + SignalR 多服务端测试

时间:2019-04-28 17:15:21      阅读:262      评论:0      收藏:0      [点我收藏+]

标签:form   ntb   src   level   lob   sch   任务   rev   route   

前言

分两个项目,一个Gatway,一个SignalR

贴代码

1、Gatway

1、引用Ocelot

2、添加一点点代码

Startup.cs

技术图片

3、简单配置ocelot

ocelot.json

{
  "ReRoutes": [
    {
      "DownstreamPathTemplate": "/{catchAll}", //下游路径
      "DownstreamScheme": "ws", //https  //下游协议
      "DownstreamHostAndPorts": [ // 下游主机及端口
        {
          "Host": "127.0.0.1",  // 这里是我后面signalr地址
          "Port": 53353
        },
        {
          "Host": "127.0.0.1",
          "Port": 53354
        },
        {
          "Host": "127.0.0.1",
          "Port": 53355
        }
      ],
      "UpstreamPathTemplate": "/gateway/{catchAll}", // 上游路径
      "UpstreamHttpMethod": [ "GET", "POST", "PUT", "DELETE", "OPTIONS" ], //上游使用的http方法
      "LoadBalancerOptions": {
        "Type": "RoundRobin" //雨露均沾
        //LeastConnection 任务少的接客
        //NoLoadBalance 天将降大任于斯人也
      }
    }
  ],
  "GlobalConfiguration": {  //全局配置
    "BaseUrl": "http://127.0.0.1:5000"
  }
}

2、signalr

1、Startup.cs

技术图片

2、chat.js

//const connection = new signalR.HubConnectionBuilder()
//    .withUrl("http://127.0.0.1:5000/gateway/chatHub")  // 这里使用http
//    .configureLogging(signalR.LogLevel.Information)
//    .build();

const connection = new signalR.HubConnectionBuilder()
    .withUrl("ws://127.0.0.1:5000/gateway/chatHub", {   // 这里使用WebSockets,不这样写连不上的
        skipNegotiation: true,
        transport: signalR.HttpTransportType.WebSockets
    })
    .configureLogging(signalR.LogLevel.Trace)
    .build();

connection.on("ReceiveMessage", (user, message) => {
    const encodedMsg = user + " says " + message;
    const li = document.createElement("li");
    li.textContent = encodedMsg;
    document.getElementById("messagesList").appendChild(li);
});

document.getElementById("sendButton").addEventListener("click", event => {
    const user = document.getElementById("userInput").value;
    const message = document.getElementById("messageInput").value;
    connection.invoke("SendMessage", user, message).catch(err => console.error(err.toString()));
    event.preventDefault();
});

connection.start().catch(err => console.error(err.toString()));

3、Program.cs

技术图片

测试

1、启动三个Signalr

技术图片

2、启动Gateway项目

技术图片

3、启动客户端

新开三个客户端,发现分配到了三个地址。

技术图片

技术图片

技术图片

也就是意味着这三个连这不同的服务端,发信息应该是不通的。这里我们测试一下。

技术图片

那再开两个客户端试试

技术图片

技术图片

不小心发了个54的消息,我们看下之前的54有没有消息。

确实有。

技术图片

4、测试结束

好了,测试完了。也没看Ocelot源码。

结论就是Ocelot这样连SignalR都是各玩个的。这样不能一起愉快的玩耍的。

所以使用其他的方式实现一下。

记录Ocelot + SignalR 多服务端测试

标签:form   ntb   src   level   lob   sch   任务   rev   route   

原文地址:https://www.cnblogs.com/hanfan/p/10784971.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!