首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ASP.NET Core 进程外(out-of-process)托管(7)《从零开始学ASP.NET CORE MVC》

在处理请求时, Kestrel 服务器将响应发送到反向代理服务器, 然后反向代理服务器最终通过网络将响应发送到请求的客户端。...在后面的视频课程中,我们将学习如何将ASP.NET Core应用程序部署到IIS并使用IIS作为反向代理服务器。...由于我们已将应用程序配置为使用进程外托管,所以当前情况下,IIS Express 已经在充当反向代理服务器了。 IIS Express接收传入的HTTP请求并将其转发给Kestrel进行处理。...Kestrel处理请求并将响应发送到IIS Express。IIS Express反过来将该响应发送到浏览器。...如果使用反向代理服务器接收传入的HTTP请求并将其转发到Kestrel服务器。同样,它从Kestrel服务器获取响应并将其发送到客户端。因此托管应用程序的进程名称是dotnet.exe。

1.5K50

与我一起学习微服务架构设计模式8—外部API模式

它可以由三部分组成: GraphQL模式:定义服务器端数据模型及其支持的查询 解析器函数:解析函数将模式的元素映射到各种后端服务。 代理类:代理类调用应用程序的服务。...执行GraphQL 使用GraphQL的主要好处是它的查询语言为客户端提供了对返回数据的令人难以置信的控制。客户端通过向服务器发出包含查询文档的请求来执行查询。...简单情况下,查询文档包含查询的名称,参数值及要返回结果的对象字段。 把模式连接到数据源 当GraphQL服务器执行查询时,必须从一个或多个数据存储中检索所请求的数据。...通过将解析函数附加到模式定义的对象类型字段,可以将GraphQL模式与数据源相关联。GraphQL通过调用解析器函数检索数据,以此实现API组合模式。...为了让客户端调用GraphQL,你需要将它与Web框架集成,如Express Web

1.4K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    hydra-microservice 中文手册(完整篇)

    将消息发送到不正常的服务可能会导致级联的结果,具体取决于应用程序体系结构的健壮性。 应用程序需要在调用它们之前了解对等微服务的状态。这样路由软件可以避免不健康的服务,并在问题致命之前将其报告出来。...Hydra-express 是包装 Hydra 和 ExpressJS 的模块。在本指南中,我们将着眼于创建一个 hydra-express 应用程序,并了解它可以做什么。...使用 hydra 的任何应用程序都可以检查这些信息。 hydra-cli 程序实际上只是一个运行 Hydra 的命令行客户端——它的大部分功能都是由 Hydra 提供的。...支持以下方案: 客户端连接到 hydra-router 并将消息发送到后端服务 后端服务可以将异步消息发送回特定客户端 客户端可以通过 hydra-router 向彼此发送消息 有关构建此类应用程序的更多信息...接收 hydra-router 实例将确保将消息路由到适当的客户端。

    5.1K10

    剖析XMLHttpRequest对象理解Ajax机制

    这一技术的优点在于,它向开发者提供了一种从Web服务器检索数据而不必把用户当前正在观察的页面回馈给服务器。...换句话说,AJAX可以使基于浏览器的应用程序更具交互性而且更类似传统型桌面应用程序。   Google的Gmail和Outlook Express就是两个使用AJAX技术的我们所熟悉的例子。...为了把数据发送到服务器,应该使用POST方法;为了从服务器端检索数据,应该使用GET方法。另外,uri参数用于指定XMLHttpRequest对象把请求发送到的服务器相应的URI。...仅当readyState值为1时,你才可以调用send()方法;否则的话,XMLHttpRequest对象将引发一个异常。该请求被使用提供给open()方法的参数发送到服务器。...通过不必把Web页面寄送到服务器而实现数据传送,XMLHttpRequest对象为客户端与服务器之间提供了一种动态的交互能力。

    1.4K20

    hydra-microservice 中文手册(下篇)

    Hydra 提供了“基本的”消息传递和排队功能,但并不打算替代 MQTT、Rabbit 和 Kafka 等服务器。因此,Hydra 并没有提供那些系统所具备的许多功能。...考虑到对 Redis 的依赖,重要的是不要创建大型排队消息, 并且 Redis 的性能会受到大规模影响。解决此问题的一种方法是将一条小消息排队,该消息指向一条数据库记录或文件系统存储。...服务静态 Web 内容 hydra-express 服务可以服务静态 Web 内容。只需创建一个名为 public 的文件夹,然后将网站文件复制到其中即可。...Hydra-cli 提供 cfg 命令,用于列出(listing)、加载(loading)和上传(uploading)配置文件数据到 Redis。...使用 hydra 的任何应用程序都可以检查这些信息。 hydra-cli 程序实际上只是一个运行 Hydra 的命令行客户端——它的大部分功能都是由 Hydra 提供的。

    5K40

    译|通过Node和Redis进行API速率限制

    缓和暴力攻击 防止分布式拒绝服务(DDOS)攻击 如何实施限速? 速率限制可以在客户端级别,应用程序级别,基础架构级别或介于两者之间的任何位置实现。...步骤 2:使用 Redis 添加速率限制器 Redis 是一个内存中键值数据库,因此它可以非常快速地检索数据。使用 Redis 实施速率限制也非常简单。 存储一个像用户 IP 地址一样的 key。...如果用户在限制之内,我们将继续执行下一个代码块,在该代码块中,我们可以允许访问受保护的资源(例如数据库)。...我们将使用 Postman 将 POST 请求发送到我们的 API 服务器,该服务器在本地运行,网址为 http:// localhost:3000。 ?...你理想的速率限制解决方案将随着时间的推移而改变,同时也会考虑到这些因素。 原文:https://codeburst.io,作者:Joyce Lin

    2K31

    为什么要使用Node.js?

    第二,开发者一定要注意不要让异常冒泡到应用顶部,这可能使整个Node.js程序崩溃。 避免异常冒泡到程序顶部,可以将错误当做回调函数的参数。...举个例子:服务端应用需要和第三方资源沟通,从多个源点拉取数据,或者将图像视频等资源存储到第三方服务。...使用Node.js的事件循环机制,我们可以构建一个强大的信息板,来监控服务器的状态,以异步的方式将数据通过WebSocket发送到客户端。 不管是内部还是公众服务,都可以通过这种技术实时报告状态。...web应用程序 使用Express.js框架可以在服务器上构建一个传统的Web应用,有一种说法,Node.js的请求响应模型用来渲染HTML页面不是最好的用处。...将Node.js单独用作前端是可能的,而且并不少见,同时保持Rails后端和对关系数据库的简单访问。 沉重的服务端计算 当涉及到大量的计算,Node.js是不是最好的平台。

    3.3K21

    React 在服务端渲染的实现

    假设你已经在客户端使用 React 构建了一个事件列表 app。该应用程序使用了您最喜欢的服务器端工具构建的API。...包括围绕与API交流的React应用程序的共同路障。 在本教程中,我们将逐步向您介绍服务器端的渲染示例。包括围绕着 APIS 交流一些在服务端渲染 React 应用程序的共同障碍。...入门 接下来让我们来看看如何将服务器端渲染添加到一个基本的客户端渲染的使用Babel和Webpack的React应用程序中。我们的应用程序将增加从第三方 API 获取数据的复杂性。...增加服务器端渲染 接下来,我们将实现服务器端渲染,以便将完全生成的HTML发送到浏览器。如果要同时查看所有更改,请查看GitHub上的差异。...,一个 Node.js 的服务器端应用程序框架: npm install express --save 我们要创建一个渲染我们的 React 组件的服务器: import express from 'express

    2.2K70

    Facebook 宣布开源 Katran,高性能第4层负载平衡器

    鉴于极高的请求量,PoP和数据中心都面临着巨大挑战,比如如何将大量的后端服务器作为单一的虚拟单元提供给外部,以及如何在后端服务器之间高效地分配工作负载。...在第二次迭代中,他们利用eXpress数据路径(XDP)框架和新的BPF虚拟机(eBPF)让软件负载均衡器和其他服务运行在一起。 ?...后端服务器选择:为了将来自某个客户端的所有数据包发送到相同的后端服务器,L4LB使用了一致性哈希,哈希值取决于传入的5元组(源地址、源端口、目标地址、目标端口和协议)数据包。...他们使用了IPVS内核模块,后端服务器的回送接口上配置了相应的VIP,所以它们可以将返回的数据包直接发送到客户端(而不是L4LB)。...RSS封装:接收端伸缩(Received Side Scaling,RSS)是针对NIC的一项重要优化,旨在通过将数据包发送到单独的CPU来均匀地在CPU之间分布负载。

    1.2K20

    「首席看应用架构」轮询,SSE 和WebSocket,如何选择合适的?

    构建实时Web应用程序有点挑战,我们需要考虑如何将数据从服务器发送到客户端。能够“主动”实现这一功能的技术已经存在了很长时间,并且仅限于两种通用方法:客户端请求或服务器请求。...实现这些的几种方法: 长/短轮询(客户端拉动) WebSockets(服务器推送) 服务器发送的事件(服务器推送) 客户端拉取-客户端以一定的定期间隔向服务器请求更新 服务器推送-服务器正在主动将更新推送到客户端...简单来说,短轮询是基于AJAX的计时器,它以固定的延迟进行调用,而长轮询则基于Comet(即,当服务器事件发生时,服务器将无延迟地将数据发送到客户端)。两者都有优点和缺点,并根据用例进行调整。...3.使用SSE: SSE是一种机制,一旦建立了客户端-服务器连接,服务器就可以将数据异步推送到客户端。然后,只要有新的“大块”数据可用,服务器就可以决定发送数据。可以将其视为单向发布-订阅模型。...开箱即用地通过HTTP / 2自动多路复用 将客户端上数据的连接数限制为一个 如何在SSE,WebSocket和Polling中进行选择?

    4.1K30

    GraphQL 初体验,Node.js 构建 GraphQL API 指南

    在传统的基于 REST 的 API 方法中,客户端发出请求,而服务端决定响应。 但是在 GraphQL 中,客户端可以精确地确定其从服务器获取的数据。...在本文中,我们将探讨使用 GraphQL 作为 API 查询语言的利弊,以及如何开始构建实现。...端点的一次调用将解决所有这些不同的位置,并以他们所请求的数据响应客户端。...如果你不确定应用程序的需求以及将来如何存储数据,则 GraphQL 在这里也很有用。要修改查询,你只需要添加所需字段的名称,这极大简化了随着时间推移而发展你的应用程序的过程。...并非每个字段都具有参数,但是在这种情况下,我们将拥有参数,因为我们需要通过 ID 来检索其用户。

    8.3K40

    Webpack DevServer和HMR原理

    ,然而它也可以作为一个单独的package来使用,以便根据需求进行更多自定义配置 搭配一个服务器来使用它,比如express. npm install --save express webpack-dev-middleware...,又依赖于其他的一些资源,那么就需要指定从哪里来查找这个内容: 比如代码是这样的:; 这样打包后浏览器无法通过相对路径去找到这个文件夹; 所以代码是这样:; 如何让它去查找到这个文件的存在?...webpack-dev-server会创建两个服务:提供静态资源的服务(express)和Socket(net.Socket) Express Server负责直接提供静态资源服务(打包后的资源直接被浏览器请求和解析...) HMR Socket Server是一个socket长连接 长连接有一个最好的好处是建立连接后双方可以通信(服务器可以直接发送文件到客户端) 当服务期间听到对应模块发上变化时,会生成两个文件.json...(manifest文件)和.js文件(update chunk) 通过长连接,可以直接将这两个文件主动发送给客户端。

    1.9K30

    SignalR简介

    实时网络功能可以让服务器代码在连接的客户端可用时立即将内容推送到连接的客户端,而不是让服务器等待客户端请求新数据。 SignalR可以用于向ASP.NET应用程序添加任何类型的“实时”Web功能。...每当用户刷新网页以查看新数据,或者页面实现长轮询以检索新数据时,它是使用SignalR的候选。示例包括仪表板和监视应用程序,协作应用程序(如同时编辑文档),作业进度更新和实时表单。...SignalR提供了一个用于创建从服务器端.NET代码调用客户端浏览器(和其他客户端平台)中的JavaScript函数的服务器到客户端远程过程调用(RPC)的简单API。...彗星运输 以下传输基于Comet Web应用程序模型,其中浏览器或其他客户端维护长期保留的HTTP请求,服务器可以使用该请求将数据推送到客户端,而客户端没有明确请求它。...从客户端到服务器的连接使用从服务器到客户端连接的单独连接,并且像标准HTML请求一样,为需要发送的每个数据段创建新连接。 Ajax长轮询。

    2.4K20

    【译】构建RESTful API的13种最佳实践

    客户端-服务器模型:RESTful API 遵循客户端-服务器模型,其中服务器为数据提供服务,而客户端连接到服务器以使用数据。...客户端和服务器之间的交互是通过 HTTP(S)请求进行的,该请求传输了请求的数据。 无状态:更重要的是,RESTful API 应该是无状态的。每个请求都被视为独立请求。...可以在 RESTful API 中访问以下 HTTP 操作: GET 请求:检索资源 POST 请求:创建资源或将信息发送到 API PUT 请求:创建或替换资源 PATCH 请求:更新现有资源 DELETE...但是,不同的编程语言使用不同的命名约定。 6.如何处理搜索,分页,过滤和排序 搜索,分页,过滤和排序等操作并不代表单独的端点。这些操作可以通过使用随 API 请求提供的查询参数来完成。...正确定义你的 API 处理的不同资源,将帮助你在未来避免资源相关的问题。定义你的资源,还要准确定义它的属性和资源之间的关系。这样一来,如何连接不同的资源就没有争议的空间了。

    1.9K10

    服务端渲染提升Web应用体验

    服务器端渲染在服务器上生成 HTML。了解 SSR 如何提升 Web 应用的性能和 SEO,以及何时使用它以及何时使用客户端渲染。...当用户请求页面时,服务器会完成所有繁重的工作并将完全渲染的页面发送到客户端。然后,客户端 JavaScript 接管以使其具有交互性。 服务器在厨房里做准备工作,浏览器只需摆盘和上菜。...请记住,虽然 SSR 提供了这些完全渲染的页面,但它并非没有权衡。服务器的工作量更大,您需要仔细处理服务器和客户端之间的状态。...让我们来探讨如何使用Next.js,一个流行的React框架,使得SSR变得简单直接: 设置一个Next.js项目。 创建服务器端渲染页面。 让Next.js处理完全渲染的HTML和客户端水合。...完全渲染的HTML被发送到客户端。 一旦浏览器中的JavaScript加载完成,页面就变得可交互。 这种方法让你享受到SSR的好处,而无需手动设置服务器或自己管理渲染过程。

    9710

    使用React和Node构建实时协作的白板应用

    本文将展示如何使用React和Node构建一个提供实时协作白板的Web应用程序。 实时协作涉及多个用户在共同任务或项目上进行动态和即时的互动。...在我们的情况下,我们将使用它来确保我们的客户端应用程序(运行在不同的源上)可以与服务器进行交互。 Socket.io :一个实时通信库,方便客户端和服务器之间的双向通信。...我们将利用 socket.io 的事件驱动架构,采用其 on 和 emit 机制,以促进客户端和服务器之间的无缝数据传输。...在客户端方面,我们将增强 updateElement 功能,使其在每次元素更新时将数据传输到服务器。...现在,让我们测试我们的应用程序: 完成这个后,每当一个客户端进行更新,所有连接到我们服务器的其他客户端都会收到更新。

    62120

    快速在你的vuereact应用中实现ssr(服务端渲染)

    前言 我们都知道, Vue和React是构建客户端应用程序的框架。...所以为了解决SPA应用遇到的这些问题, 我们必须考虑SSR: 服务端渲染(ssr),是指由服务器端完成页面的HTML 结构拼接,并且直接将拼接好的HTML发送到浏览器,然后为其绑定状态与事件,成为完全可交互页面的处理技术...对于服务端渲染的页面,服务端可以直接将带数据的内容通过 HTML 文本的形式返回,搜索引擎爬虫可以轻易的获取页面内容,而对于客户端渲染的应用,客户端必须执行服务器返回的 Javascript 才能得到正确的网页内容...Rendertron 服务的 /render/客户端请求地址 路由,让 Rendertron 帮助执行网页内的 Javascript,并将最终内容返回给搜索引擎爬虫。...', })); // 正常的路由和页面渲染逻辑 app.use(...); app.listen(81); 所以为了降低开发成本笔者建议可以采用rendertron的方案, 单独部署一套服务器用来实现

    2.1K20
    领券