第四章SignalR自托管主机
第四章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>: ' + 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自托管主机相关推荐
- SignalR 2.0 系列: SignalR 自托管主机
这是微软官方SignalR 2.0教程Getting Started with ASP.NET SignalR 2.0系列的翻译,这里是第六篇: SignalR 自托管主机 原文: SignalR S ...
- Lumen为《堡垒之夜:大逃杀》第四章带来实时全局光照
Lumen为<堡垒之夜:大逃杀>第四章带来实时全局光照 - Unreal Engine 图像部门工程研究员Daniel Wright和图像部门技术总监Krzysztof Narkowicz ...
- 计算机网络第四章学习通题目及答案
目录 分类的 IP 地址 IP地址与硬件地址 ARP与RARP协议 IP数据报的格式 划分子网 第七次练兵 分组转发算法 CIDR(构造超网) ICMP报文及应用 内部网关协议RIP 分类的 ...
- 王道考研 计算机网络笔记 第四章:网络层
本文基于2019 王道考研 计算机网络: 2019 王道考研 计算机网络 个人笔记总结 第一章:王道考研 计算机网络笔记 第一章:概述&计算机网络体系结构 第二章:王道考研 计算机网络笔记 第 ...
- python环境设置_CentOS 7.2环境搭建实录(第四章:python环境配置)
第四章:python环境配置 使用环境工具 python 环境工具 python 2.7.5 # python2版本,系统自带 pip 9.0.1 # python2版本的pip,python工具集, ...
- linux shell 变量减法_第四章 shell和环境变量
第四章 shell和环境变量 4.1 shell简介 4.1.1 编译器 一台计算机从基本架构上讲,由最基本的硬件组成硬件结构(如:cpu.内存.主板.声卡.显卡等),我们知道,硬件组成完备,但 ...
- 鸟哥的Linux私房菜(服务器)- 第十四章、账号控管: NIS 服务器
第十四章.账号控管: NIS 服务器 最近更新日期:2011/07/28 有没有想过,如果我有十部 Linux 主机,这十部主机仅负责不同的功能,事实上,所有的主机账号与对应的密码都相同! 那么我是将 ...
- 鸟哥的Linux私房菜(服务器)- 第四章、连上 Internet
第四章.连上 Internet 最近更新日期:2011/07/20 终于要来到修改 Linux 网络参数的章节了!在第二章的网络基础中, 我们知道主机要连上 Internet 需要一些正确的网络参数设 ...
- 鸟哥的Linux私房菜(基础篇)- 第二十四章、 X Window 配置介绍
第二十四章. X Window 配置介绍 最近升级日期:2009/08/07 在 Linux 上头的图形介面我们称之为 X Window System,简称为 X 或 X11 罗!为何称之为系统呢?这 ...
最新文章
- CRMEB SSL certificate problem, verify that the CA cert is OK
- There is no Action mapped for namespace [/]
- python小案例随机点名_python用tkinter实现一个简易能进行随机点名的界面
- ppt 的局部分大功能软件介绍.ZoomIt
- excel图表之道_学习笔记:Excel之图表布局
- 路漫漫其修远兮,吾要上下左右前后而求索
- golang interface 类型转换_Golang面试题41道
- VMware中安装linux系统(可视化界面centOS 7)
- vep格式用什么播放器linux,vep格式视频用什么播放器打开
- 两款Java中小医院信息管理系统源码
- 阿里巴巴内部面试资料
- 信息系统项目管理师考试重点和难点分析
- php抓取神马搜索结果,php判断神马搜索引擎蜘蛛蜘蛛的方法
- 关于一些Ubuntu网络问题的解决办法
- 一文带你了解800万像素车载摄像头
- 笔记 | 杂谈控制固定效应这件事
- 未成熟男人; 成熟男人
- 云计算机房建设方案,云服务器 机房建设方案
- 万般皆下品惟有读书高,面试各种后的领悟
- Android 增量更新实例
热门文章
- android生成车票动效,Android项目源码功能齐全的12306火车票订票系统项目
- 机组:真值、原码、反码、补码、移码
- 在使用 NModBus 开发Modbus协议数据时对待无符号16整形的问题(UShort转Short)
- TensorFlow入门教程(十):LSTM网络实现手写字体识别
- 解决错误Annotation processors must be explicitly declared now
- Linux安装Redis、远程连接Redis
- 关于 js 数组遍历的几种方式
- tinyxml2 01 基本使用
- Python计时工具
- 杰理的蓝牙芯片的key是什么?以及该如何添加key?杰理key文件原理