第四章SignalR自托管主机

SignalR服务器通常在IIS的Asp.Net应用程序上承载,但它也可以使用自托管库来作为自托管的主机来运行(就像控制台应用程序或Windows服务那样)与Signal2.0一样,自托管库是基于.Net开放式Web接口(OWIN)来构建的。OWIN定义了.Net Web服务器和Web应用程序之间的抽象接口,将Web应用程序从服务器上解耦,使得OWIN可以在IIS之外建立自托管主机。

那我们为什么不在IIS中进行托管SignalR呢?可参考以下理由:

1)不能安装IIS环境或IIS不能使用,比如无IIS的服务器主机

2)考虑到性能,需要避免IIS的额外开销。

3)SignalR运行在Windows服务或Azure工作角色,或被用于其他现存的应用程序。

(一般windows操作系统服务器都可安装IIS,非windows操作系统服务器都不能使用-_-!!!;SinglaR放在IIS中占的资源多还是自托管占资源多,运行效率和性能如何,都需要测试好;)

1.设置项目:

在本例子中,您将创建托管在控制台应用程序中的服务器,当然,将其承载在Windeos服务及Azure工作角色中也是可行的。

1)已管理员权限运行VS2013,新建一个控制台应用程序,命名为”SignalRSelfHost“并确定。

2)打开程序包管理控制台。

3)在控制台中输入一下命令

Install-Pagkage Microsoft.AspNet.SignalR.SelfHost

此命令将SingalR自托管库添加到项目中。

4)继续在控制台输入以下命令:

Install-Package Microsoft.Owin.Cors

此命令将OWIN核心库添加到项目中,因为SignalR主机与网页客户端端之间在不同的域中运行,该库将用于跨域支持。由于SignalR服务和Web客户端运行在不同的端口上,这意味着如果想在这些组件之间进行通讯,则必须启动这些组件中的跨域功能。

5)替换Program.cs中的代码:

using System;

using Microsoft.AspNet.SignalR;

using Microsoft.Owin.Hosting;

using Owin;

using Microsoft.Owin.Cors;

namespace SignalRSelfHost

{

class Program

{

static void Main(string[] args)

{

string url = "http://localhost:8080";

using (WebApp.Start(url))

{

Console.WriteLine("Server running on {0}", url);

Console.ReadLine();

}

}

}

class Startup

{

public void Configuration(IAppBuilder app)

{

app.UseCors(CorsOptions.AllowAll);

app.MapSignalR();

}

}

public class MyHub : Hub

{

public void Send(string name, string message)

{

Clients.All.addMessage(name, message);

}

}

}

上面代码包含了三个类:

A:Program,包含了Mian方法定义执行的主路径。在该方法中,指定了本地主机使8080端口来启动该Web应用程序。当然,您也可以实现SSL来进一步提高安全性。

B:Startup,包含了SignalR服务器的配置(本例子中,仅仅使用了UserCors配置类 ,并调用MapSignalR,为集线器建立路由映射。

C:MyHub,SignalR的集线器实现类,用于提供客户端服务。这个类还包含了一个方法:Send,用于将接收到的客户端消息广播给其他已连接的客户端。

6)编译并运行,在服务器的地址将显示在控制台中。

7)如果执行失败,除了发生System.Relection.TargetInvocationException错误,您需要给管理员权限重新运行VS2013并重新编译运行。

8)在进行下一步前,请关闭控制台程序。

2.使用JavaScript客户端访问服务器端:

在本例子中,您将使用同入门教程一致的JS客户端。我只是进行一项修改,即定义集线器URL,作为自托管主机,服务器不一定在相同的URL作为连接地址(参考反向代理及负载平衡),所以URL需要显示定义。

1)  在解决方案资源管理器中,添加Asp.Net Web应用程序,命名为”JavascriptClient”,然后确定。

2)已空模版创建项目。

3)在包管理控制台中,在默认项目下拉选择“JavaScriptClient“项目,并执行一下命令

Install-Package Microsoft.AspNet.SignalR.JS

此命令安装客户端所需要的SignalR以及jQuery库

4)添加一个新的Html页面,命名为“Default.html“

5)用以下的代码替换Html中的内容,同样需要确认代码中引用的脚本路径是否一致。

<!DOCTYPE html>

<html>

<head>

<title>SignalR Simple Chat</title>

<style type="text/css">

.container {

background-color: #99CCFF;

border: thick solid #808080;

padding: 20px;

margin: 20px;

}

</style>

</head>

<body>

<div class="container">

<input type="text" id="message" />

<input type="button" id="sendmessage" value="Send" />

<input type="hidden" id="displayname" />

<ul id="discussion"></ul>

</div>

<!--Script references. -->

<!--Reference the jQuery library. -->

<script src="Scripts/jquery-1.10.2.min.js"></script>

<!--Reference the SignalR library. -->

<script src="Scripts/jquery.signalR-2.0.3.min.js"></script>

<!--Reference the autogenerated SignalR hub script. -->

<script src="http://localhost:8080/signalr/hubs"></script>

<!--Add script to update the page and send messages.-->

<script type="text/javascript">

$(function () {

//Set the hubs URL for the connection

$.connection.hub.url = "http://localhost:8080/signalr";

// Declare a proxy to reference the hub.

var chat = $.connection.myHub;

// Create a function that the hub can call to broadcast messages.

chat.client.addMessage = function (name, message) {

// Html encode display name and message.

var encodedName = $('<div />').text(name).html();

var encodedMsg = $('<div />').text(message).html();

// Add the message to the page.

$('#discussion').append('<li><strong>' + encodedName

+ '</strong>:&nbsp;&nbsp;' + encodedMsg + '</li>');

};

// Get the user name and store it to prepend to messages.

$('#displayname').val(prompt('Enter your name:', ''));

// Set initial focus to message input box.

$('#message').focus();

// Start the connection.

$.connection.hub.start().done(function () {

$('#sendmessage').click(function () {

// Call the Send method on the hub.

chat.server.send($('#displayname').val(), $('#message').val());

// Clear text box and reset focus for next comment.

$('#message').val('').focus();

});

});

});

</script>

</body>

</html>

注意:次行代码生命了SignalR的基础连接URL:

$.connection.hub.url = "http://localhost:8080/signalr";

6)在解决方案上右击,设置多个启动项目为启动

7)在Default.html上右击,设置为起始页。

8)运行该项目,将弹出控制台服务以及Web页面,如果Web页面在控制台服务器启动前执行,您需要重新刷新一次页面。

9)您可以输入用户名,打开多个浏览器来进行多用户的聊天室进行测试了。^-^

第四章SignalR自托管主机的更多相关文章

  1. [渣译文] SignalR 2.0 系列: SignalR 自托管主机

    原文:[渣译文] SignalR 2.0 系列: SignalR 自托管主机 英文渣水平,大伙凑合着看吧…… 这是微软官方SignalR 2.0教程Getting Started with ASP.N ...

  2. 《ASP.NET SignalR系列》第四课 SignalR自托管(不用IIS)

    从现在开始相关文章请到: http://lko2o.com/moon 接着上一篇:<ASP.NET SignalR系列>第三课 SignalR的支持平台 一.概述 SignalR常常依托于 ...

  3. REDTEAM 指南---第四章 外部侦察

    第四章 外部侦察 贡献者:Haythem Arfaoui 翻译BugMan 主动侦察 介绍 主动足迹涉及使用可以帮助您收集更多信息的工具和技术 有关目标的信息.与被动足迹不同的是,过程永远不会“触及” ...

  4. 第四章 使用Docker镜像和仓库(二)

    第四章 使用Docker镜像和仓库(二) 回顾: 开始学习之前,我先pull下来ubuntu和fedora镜像 [#9#cloudsoar@cloudsoar-virtual-machine ~]$s ...

  5. 第二章SignalR所支持的平台

    第二章SignalR所支持的平台 SignalR支持各种服务器和客户端的配置.此外,每种传输方式都有自身的配置要求和限制:如果某种传输方式不被系统支持,SignalR优雅地将故障转移到其他类型的传输方 ...

  6. JAVA: httpclient 详细说明——第四章;

    httpclient 具体解释--第一章. httpclient 具体解释--第二章: httpclient 具体解释--第三章: httpclient 具体解释--第四章: httpclient 具 ...

  7. 《linux就该这么学》第四节课笔记,三章和四章开始!

    第三章 (根据课本和在线培训视频排版总结,借鉴请改动)         右键可打开终端练习             3.1:输入输出重定向 输入重定向:符号 "<" ,是一种 ...

  8. CentOS 7.4 初次手记:第四章 CentOS安全了解

    第四章 CentOS安全了解... 66 第一节 user.group.chmod. 66 I 10位文件属性... 66 II user/group增删改... 67 III user/group配 ...

  9. C# Language Specification 5.0 (翻译)第四章 类型

    C# 语言的类型分为两大类:值类型(value type)和引用类型(reference type),而它们又都同时具有至少一个类型形参的泛型类型(generic type).类型形参(type pa ...

随机推荐

  1. HDU 4721 Food and Productivity (二分+树状数组)

    转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents    by---cxlove 题意 :给出n * m的格子,每个格子有两个属性f ...

  2. Oracle表空间常用操作

    --创建表空间 create tablespace test datafile 'E:\test2_data.dbf' SIZE 20M autoextend on next 5M maxsize 5 ...

  3. hdu 4740 The Donkey of Gui Zhou(dfs模拟好题)

    Problem Description There was no donkey ,) , the down-right cell ,N-) and the cell below the up-left ...

  4. js正则判断电话/手机/邮箱/

    用途:校验ip地址的格式 输入:strIP:ip地址返回:如果通过验证返回true,否则返回false:*/ function isIP(strIP) { if (isNull(strIP)) ret ...

  5. HibernateTemplate 常用方法

    HibernateTemplate 提供非常多的常用方法来完成基本的操作,比如通常的增加.删除.修改.查询等操作,Spring2.0更增加对命名SQL查询的支持,也增加对分页的支 持.大部分情况下,使 ...

  6. ImageButton与Button

    1.Button控件 Butotn控件,主要用来实现一些命令操作,通过注册监听事件来实现.首先需要在xml文档中放入一个button按钮. <Button android:id="@+ ...

  7. jsoup 解析html 页面数据

    我html 页面元素: /html/body/table[2]/tbody/tr[1]/td/table/tbody/tr[1]/td[2]/font/html/body/table[2]/tbody ...

  8. mysql和VS2010 C++链接过程中出现的问题

    PS:二者连接的过程主要参考这篇博客园文章,http://www.cnblogs.com/justinzhang/archive/2011/09/23/2185963.html 这篇博客园的文章中的代 ...

  9. "Classifying plankton with deep neural networks" notes

    cross entropy loss is not quite the same as optimizing classification accuracy. Althougth the two ar ...

  10. Gesture(手势)浅析

    1.Gesture的作用 ①在触摸屏上的连续触摸行为,形成某个方向上的移动趋势  (利用手势检测) ②连续画出一个不规则的行为  (利用增加手势) 2.手势检测(GestureDetector) // ...