- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在开发一个服务器体系结构,用于从远程嵌入式设备发送/接收消息,该设备将托管在WindowsAzure上。前端服务器将与这些设备保持持久的TCP连接,我需要一种在后端与它们通信的方法。
问题事实:
设备:~10000
设备向服务器发送消息的频率:1/min
来自服务器端的消息频率(例如来自用户操作、预定触发器等):100/天
消息负载的平均大小:64字节
向上沟通
这些设备经常发送信息(传感器读数)。由于我们可以批量收集/插入这些传感器读数,并且它们不需要顺序保证,因此对这些数据的约束不是很强。我认为处理它们的最佳方法是将它们放入存储队列中,让工作进程每隔一段时间轮询队列并转储数据。当然,我必须注意确保工作进程足够频繁地执行此操作,这样队列就不会无限地备份。azure存储队列的最大批处理大小是32,但我考虑的可能不止这些:比如每隔1000次读取或30秒(以先到者为准)发布到数据存储。
下行通信
服务器发送更新和通知的频率要低得多。这是一个稍微难一点的问题,我可以在这里看到两个可行的范例(其中有些是混合的)。可以:
为每个设备创建一个服务总线队列(或一个具有数千个订阅的队列-限制为队列数为10000)
在数据库中有一个状态表,其中包含设备将发送给它们的特定消息类型的最新“状态”
有了选项1,应用服务器只需将消息以一种火上浇油的方式排队。然而,在前端服务器上,有很多事情必须发生。我看到的问题包括:
监视10000个队列(或队列中的多个订阅)
显然,Azure SDK会重用订阅的连接
队列)
连接管理
如果设备断开连接,则不再监视队列。
如果设备长时间断开连接,则需要使消息过期(这样队列就不会备份)
需要启用某种类型的“刷新”机制,以便在设备重新联机时更新其完整状态。
好消息是,服务总线队列是持久的,通过会话可以安排消息以先进先出的方式发送。
使用选项2,DB将存储一个表,该表将维护所有设备的状态。前台服务器(每隔几秒钟左右)将定期检查此表,以查看应用程序服务器是否对其进行了状态更改。然后,面向前端的服务器将发送到设备。这消除了对FIFO排队的要求,理由是该消息包含最新状态,并且不必与其他发送给同一设备的消息竞争。消息是短暂的:如果失败,那么当设备重新连接并请求刷新时,或者在前向服务器的下一个检查间隔时,将重新发送消息。
在这种情况下,对队列的需求似乎被消除了,但是数据库在这里成为了瓶颈,我担心它的可扩展性不够。
这两种方法都是可行的,我觉得这个问题已经变得太大了(尽管我可以在必要时提供更多的描述)。只是想感受一下什么是可能的,什么是通常会做的,如果我缺少一些基本的东西,我可以利用云中的什么东西来不重新发明轮子。
最佳答案
如果您可以通过设备发送的消息来识别设备(可能是设备ID/IMEI/MAC地址),那么您可以将队列数从10000减少到1个队列,并且也不需要10000个订阅。这也有助于您向下通信,因为您将能够识别设备并将消息发送到适当的套接字。
正如您所提到的连接持续时间更长,您可以将命令传递到已连接的设备,并决定如何处理未连接的设备的命令。
希望有帮助
关于azure - Azure上的云架构,用于物联网,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22644273/
似乎有很多方法可以在 Azure 中自动使用 PowerShell。由于 ARM 模板是最新的,Azure 中的其他 PowerShell 选项是否已过时?这些工具/脚本之间有什么区别: Azure
我正在开发一个将托管在 Azure 中的 Web API。我想使用 Azure 诊断将错误记录到 Azure 表存储中。在经典门户中,我可以将日志配置为转到 Azure 表存储。 Classic Po
Azure 文件存储事件可以触发 Azure WebJob 或 Azure Function 吗? 例如,在文件夹“/todo/”中创建文件时。 最佳答案 我们目前没有任何 Azure 文件绑定(bi
我需要创建一个逻辑应用程序,我的要求是,我需要从 azure data Lake Gen2 文件夹迁移 json 文件,并根据某些值需要将该 json 转换为 xml,然后将其发送到 SQL。 因此,
我使用 VS Code 创建了 1 个 node.js 和 1 个 java Azure Function 当我使用 VS Code 将这两个函数部署到 Azure 时,我最终获得了这么多 Azure
收集 Azure 诊断数据时,暂存槽是否也会将诊断数据发送到 WadPerformanceCounters 表? 如果是这样,我该如何关闭它?或者在阅读诊断信息时如何区分暂存/生产。 我不想显示有关我
您好,我是 Azure 的新手。我有 VS 2012 和 Azure SDK 2.1,当我使用模拟器运行我的 Web 应用程序时一切正常。但是当我在 azure 上部署时出现错误消息: Could n
我很难区分 Azure 订阅和 Azure 租户有何不同?我尝试使用示例来弄清楚,但每次我得出的结论是它们在某种程度上是相同的?如果租户是组织在注册 Microsoft 云服务时接收并拥有的 Azur
如果我想在 Azure Insights 中设置自定义指标集合,并以(近)实时的方式可视化其中一些指标,并查看聚合的历史数据,我应该使用 Azure Metrics Explorer 还是 Azure
我想了解具有以下配置的 Azure 数据工厂 (ADF) 的现实示例/用例: Azure 集成运行时 (AIR) 默认值 自托管集成运行时(SHIR) 其他问题: 这两种配置(AIR 和 SHIR)是
请参阅下面来自 Azure 服务总线的指标。想要识别请求数量中的背景噪音|流量较低时的响应。假设振荡请求| session 中 amqp 握手的响应是潜在的。只是不明白这是什么类型的握手?从总线接收的
此问题与 Azure 事件中心和 Azure 服务总线之间的区别无关。 问题如下: 如果您将Azure Events Hub添加到您的应用程序中,那么您会注意到它依赖于Azure Service Bu
这两个事情是完全不同的,还是它们能完成的事情大致相同/相似? 最佳答案 Azure 辅助角色是“应用程序场”中您自己的一组虚拟机。您可以以分布式方式在它们上运行任何代码。通常,您编写业务代码以在这些服
我目前正在使用 Windows Azure 虚拟机来运行 RStudio, 我的虚拟机是 Windows Server R2 2012,它是 Azure 上的一项附加服务。 我还有一个 Azure 存
我们正在寻找托管一个网站(一些 css、js、一个 html 文件,但不是 aspx、一个通用处理程序)。 我们部署为: 1) Azure 网站 2) Azure 云服务 两种解决方案都有效。但有一个
我想从 Azure 表创建 blob。 AzCopy 支持此功能,但我找不到任何说明数据移动 API 也支持它的文档。此选项可用吗? https://azure.microsoft.com/en-us
This article表示 Azure 订阅所有者有权访问订阅中的所有资源。但是,要访问 Azure 数据库,必须是数据库中的用户,或者是 Azure Admin AD 组的成员。 无论 SQL 安
我尝试使用以下代码将 XML 文件上传到 Azure FTP 服务器: https://www.c-sharpcorner.com/article/upload-and-download-files-
除了 Azure 服务总线使用主题而 Azure 事件中心基于事件 - Azure 事件中心和 Azure 服务总线之间是否有任何根本区别? 对我来说,事件和消息之间没有真正的区别,因为两者只是不同类
我有一个通过虚拟网络网关连接到 Azure 虚拟网络的 Windows VPN 客户端。目标#1 是使用其内部 IP 地址连接到我的虚拟机。这有效。 第二个目标是使用其内部计算机名称进行连接(因为 I
我是一名优秀的程序员,十分优秀!