在我的 IIS 7.5 上,我的 SignalR 应用程序总是使用长轮询。根据我的搜索,IIS 7.5 还不支持 WebSockets。
我希望,我错过了一些在 IIS 7.5 中启用 WebSockets 的工具或配置。还是我没有?
您不能在 IIS 7.5(换句话说,在 Windows Server 2008 R2 或 Windows 7)上使用 WebSocket,因为它需要 HTTP.sys 级别更改 AFAIK。因此,您需要 IIS 8.0 和 Windows Server 2012 或 Windows 8 组合来利用 WebSocket。此外,IIS Express 8.0 也支持 WebSockect,但如果您使用的操作系统低于 Windows 8 或 Windows Server 2012,您仍然无法利用它。
下面总结了使用 IIS 7.5 在 Windows 2008r2 上托管所需的设置步骤:
更新 SignalR 应用程序的 web.config 文件以启用“为所有请求运行所有托管模块”(简而言之,这是 RAMMFAR 设置)。
更新使用 SignalR与服务器通信的网页:添加对 json2.js 库的引用。添加一个标签,强制内容以最近的浏览器模式显示。
使用 IIS 7.5 设置 Windows Server 2008r2,如下所示: 安装 SignalR 应用程序所需的 .NET Framework 版本。创建一个站点并将其与适当的应用程序池相关联。
更新 Signalr 应用程序的 Web.config 文件
在 SignalR 应用程序的 web.config 文件中,添加 RAMMFAR 设置以启用为所有请求运行所有托管模块。需要此设置才能让 SignalR 示例应用程序在所有浏览器中的 Windows 2008r2 和 IIS 7.5 上运行。
<system.webServer>
<modules runAllManagedModulesForAllRequests="true">
</modules>
</system.webServer>
更新使用 SignalR 的网页
在使用 SignalR 与服务器通信的应用程序网页中,添加以下代码。
添加对 json2.js JSON 解析器库的引用。该脚本为以前没有它的浏览器版本提供了 JSON 解析器。您可以通过以下两种方式之一添加脚本:将 NuGet 包 json2.js 添加到您的项目中,然后在您的网页中引用它:
或者作为替代方案,在 CDN 上引用 json2.js:
在页面的 head 部分添加以下标记。此标记(特别是 IE=edge 值)强制 Internet Explorer 以可用的最新版本显示内容,而不是阻止 SignalR 代码工作的早期模式(例如 IE7)。
设置 Windows Server 2008r2 和 IIS 7.5
如前所述,我在 .NET 4 上的 SignalR 入门教程中构建了示例 SignalR 应用程序。这是 Windows 2008r2 和 IIS 7.5 上的常见托管方案。该服务器是 Windows Server 2008r2 和 IIS 7.5 的新默认默认安装。
安装所需的 .NET Framework 版本。在这种情况下,我安装了 .NET Framework 4。在 IIS 管理器中创建一个新站点,并将该站点与应用程序池相关联。使用集成模式应用程序池,SignalR 不支持经典模式。对于这个应用程序,我使用了 ASP.NET v4.0 应用程序池。
完成上述设置步骤后,我能够将基于 .NET Framework 4 版本的 SignalR 入门示例部署到服务器,它在 IE(版本 8、9 和 10)、Chrome 和Firefox,即使它使用后备传输方法(IE 中的永久帧,以及其他浏览器中的服务器发送事件)。SignalR 开发人员的有趣之处在于,除了上述步骤之外,我无需在应用程序中的任何位置更改任何一行 SignalR 代码即可完成这项工作。
这是一个简单的案例,但表明当服务器上的 websockets 支持不可用时,SignalR 确实支持“自动回退”到早期的传输机制。