我有一个简单的Hub
在 Azure 中运行,我可以通过 Windows 中的控制台应用程序完美地工作。
我刚刚构建了一个简单的测试 Xamarin.iOS 应用程序,它给出了一些奇怪的行为。
- 随机在 LTE/Wifi 或模拟器/设备上 - 调用集线器方法失败并显示
There was an error invoking Hub method X
- 随机大约 50% - 一切都运行得很好,就像 Windows 上的控制台应用程序一样 - 两者甚至可以互相发送消息
我在 iPhone 5S 和 iPhone 4S 设备上对此进行了测试。
关于为什么会发生这种情况有什么想法吗?我正在使用版本 2.0.0 上的便携式 NuGet 包。
UPDATE:
这是启用跟踪时得到的结果(我清空了我的域):
2013-11-25 07:47:48.204 MyApp[5163:80b] 13:47:48.1865420 - null - ChangeState(Disconnected, Connecting)
2013-11-25 07:47:49.025 MyApp[5163:6b03] 13:47:49.0247930 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: GET http://mydomain.cloudapp.net/signalr/connect?transport=serverSentEvents&connectionToken=pVF6LN7KBOem7Ng2hrhx6dSByFe%2BxCr4u6RlY5V%2FtKf%2BHmOoJD5DfVpMySiUuDOaiIPlHI%2FtliqvuddvcDxnZQqi9tIYAxuyZOjYSG%2B9%2Fnx%2FQ%2B6m&connectionData=[{"Name":"MainHub"}]&noCache=c3d54c1d-ee78-49cc-85b4-2c87a024c32a
2013-11-25 07:47:49.203 MyApp[5163:6b03] 13:47:49.2023660 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: OnMessage(Data: initialized)
2013-11-25 07:47:49.319 MyApp[5163:6b03] 13:47:49.3189120 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: OnMessage(Data: {"C":"s-0,CF9","S":1,"M":[]})
2013-11-25 07:47:49.332 MyApp[5163:6b03] 13:47:49.3318670 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - ChangeState(Connecting, Connected)
2013-11-25 07:47:49.634 MyApp[5163:6b03] 13:47:49.6339640 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: OnMessage(Data: {"C":"s-0,CFA","G":"54eYUWzlKXr9ezIoP1rZvj4DOQ00lfpXZ62PV+HwgzqCvgET2otfFNud1KzX24MjGplzkOwpyzqrVJ1jffBMyWppsDt9Tl+D25btqsxJWt6bBg3v4YfwobBKbpZaScgk/gPp5w==","M":[]})
2013-11-25 07:47:49.703 MyApp[5163:6b03] 13:47:49.7029070 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: OnMessage(Data: {"C":"s-0,CFB","M":[]})
2013-11-25 07:47:58.090 MyApp[5163:6b03] 13:47:58.0894910 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: OnMessage(Data: {})
2013-11-25 07:48:08.108 MyApp[5163:6b03] 13:48:08.1084000 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: OnMessage(Data: {})
2013-11-25 07:48:18.118 MyApp[5163:6b03] 13:48:18.1178390 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - SSE: OnMessage(Data: {})
2013-11-25 07:48:22.097 MyApp[5163:6b03] 13:48:22.0968150 - d84a25b3-b426-4f0b-b4bc-7d170e3c1bd9 - OnMessage({"I":"0","E":"There was an error invoking Hub method 'MainHub.SignOn'."})
空的OnMessage
,失败后将继续每隔一段时间打印一次。
更新#2
经过测试和进一步检查,它似乎比 LTE 与 Wifi 更有可能是随机的。回顾一下,在我的本地机器上运行一切正常。只是部署到 Azure 时并非如此。基本上,在随机发生的情况下,调用集线器方法将会超时。
以下是我所做的一些事情,这些事情使这个问题变得更加罕见,但它仍然会发生:
- Force
LongPollingTransport
,无论怎样
- Add a
Task.Delay
在成功之间Start
和第一个Invoke
I set EnableDetailedErrors
to true
在服务器上,这似乎是服务器端发生的情况:
Error in SignOn: System.Threading.Tasks.TaskCanceledException: A task was canceled.
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at MyNamespace.MainHub.<SignOn>d__0.MoveNext(); TraceSource 'w3wp.exe' event
我认为这与客户放弃有关。我看到了一些Github 问题 https://github.com/SignalR/SignalR/issues/606Azure 上与此相关,但它们被标记为已关闭...
更新#3
一时兴起,我将其部署到标准 Azure 网站部分而不是云服务。之后一切正常。有什么想法吗?显然我可以使用 Azure 网站来实现此目的,但为什么它不能作为云服务工作呢?