- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我搜索了在 azure 表存储中存储传感器输出数据的最佳实践,但没有得到最佳答案。我目前正在开发一个项目,该项目包括将传感器数据存储到 azure 表存储中。目前我使用分区键作为 Sensor ID 。我每秒都在存储传感器输出。目前正在使用大约 100 个传感器。想象一下每天都在存储大量数据。因此,当我按日期搜索特定传感器数据时,我的网络应用程序性能下降。有没有更好的方法来提高网络应用程序的性能?将传感器 ID 更改为分区键怎么样?代码在这里并不重要。我需要一个合乎逻辑的解决方案。也许这个问题会帮助很多正在处理这种情况的开发人员。
更新
每个传感器提供 10 个不同的输出和日期,即输出日期时间。所以它们位于每个传感器 ID 的同一行。我正在使用日期范围和传感器 ID 获取传感器数据
分区键 - 传感器 ID,RowKey - 日期时间,10 个输出列和输出日期
这是我的代码
var query = TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, sensorID);
var dateFilter = TableQuery.CombineFilters(
TableQuery.GenerateFilterConditionForDate("outputdate", QueryComparisons.GreaterThanOrEqual, Convert.ToDateTime(from)),
TableOperators.And,
TableQuery.GenerateFilterConditionForDate("outputdate", QueryComparisons.LessThanOrEqual, Convert.ToDateTime(to))
);
query = TableQuery.CombineFilters(query, TableOperators.And, dateFilter);
var rangeQuery = new TableQuery<TotalizerTableEntity>().Where(query);
var entitys = table.ExecuteQuery(rangeQuery).OrderBy(j => j.date).ToList();
outputdate表示输出生成时间。这是日期时间。所有输出具有相同的输出时间。
最佳答案
首先,我强烈建议您阅读 Azure Storage Table Design Guide: Designing Scalable and Performant Tables
。这将为您提供有关如何构建数据的很多想法。
现在来看看您当前的实现。我注意到,您在查询中包含 PartitionKey
(顺便说一句,这非常好),但随后在查询中添加一个非索引属性 (outputdate
),如下所示出色地。这将导致所谓的“分区扫描”。对于较大的表,这会产生问题,因为您的查询将扫描整个分区以查找匹配的 outputdate
属性。
您提到您存储的datetime
值是RowKey
。假设 RowKey
值与 output
日期的值匹配,我建议在查询中使用 RowKey
而不是此非索引属性。 RowKey
(以及PartitionKey
)是表中仅有的两个索引属性,因此查询速度相对要快得多。
将日期/时间保存为 RowKey
时,我建议将其转换为刻度 (DateTime.Ticks),然后保存,而不是简单地将日期/时间值转换为字符串。如果您采用这种方法,我建议在此刻度前面添加 0
,以便所有值的长度相同(执行类似 DateTime.Ticks.ToString("d19")
)。
您还可以将RowKey
另存为Reverse Ticks
,即(DateTime.MaxValue.Ticks - DateTime.Ticks).ToString("d20")
.这将确保所有最新条目都添加到表的顶部而不是底部。这在您对查询最新记录更感兴趣的情况下会有所帮助。
如果您始终查询特定传感器,则将每个传感器的数据保存在单独的表中可能不会有什么坏处,即每个传感器都有一个单独的表。这将为您释放一把 key 。您可以使用日期/时间值(当前存储为 RowKey
)作为 PartitionKey
,也可以使用其他值作为 RowKey
。此外,它还允许您跨存储帐户进行扩展 - 某些传感器的数据将进入一个存储帐户,而其他传感器的数据将进入另一个存储帐户。您只需在某个地方保存此关系,以便数据到达正确的存储帐户/表。
关于azure - 在 azure 表存储中创建分区键以存储传感器输出数据的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44840687/
我正在使用 OUTFILE 命令,但由于权限问题和安全风险,我想将 shell 的输出转储到文件中,但出现了一些错误。我试过的 #This is a simple shell to connect t
我刚刚开始学习 Java,我想克服在尝试为这个“问题”创建 Java 程序时出现的障碍。这是我必须创建一个程序来解决的问题: Tandy 喜欢分发糖果,但只有 n 颗糖果。对于她给第 i 个糖果的人,
你好,我想知道我是否可以得到一些帮助来解决我在 C++ 中打印出 vector 内容的问题 我试图以特定顺序在一个或两个函数调用中输出一个类的所有变量。但是我在遍历 vector 时收到一个奇怪的错误
我正在将 intellij (2019.1.1) 用于 java gradle (5.4.1) 项目,并使用 lombok (1.18.6) 来自动生成代码。 Intellij 将生成的源放在 out
编辑:在与 guest271314 交流后,我意识到问题的措辞(在我的问题正文中)可能具有误导性。我保留了旧版本并更好地改写了新版本 背景: 从远程服务器获取 JSON 时,响应 header 包含一
我的问题可能有点令人困惑。我遇到的问题是我正在使用来自 Java 的 StoredProcedureCall 调用过程,例如: StoredProcedureCall call = new Store
在我使用的一些IDL中,我注意到在方法中标记返回值有2个约定-[in, out]和[out, retval]。 当存在多个返回值时,似乎使用了[in, out],例如: HRESULT MyMetho
当我查看 gar -h 的帮助输出时,它告诉我: [...] gar: supported targets: elf64-x86-64 elf32-i386 a.out-i386-linux [...
我想循环遍历一个列表,并以 HTML 格式打印其中的一部分,以代码格式打印其中的一部分。所以更准确地说:我想产生与这相同的输出 1 is a great number 2 is a great
我有下面的tekton管道,并尝试在Google Cloud上运行。集群角色绑定。集群角色。该服务帐户具有以下权限。。例外。不确定需要为服务帐户设置什么权限。
当尝试从 make 过滤非常长的输出以获取特定警告或错误消息时,第一个想法是这样的: $ make | grep -i 'warning: someone set up us the bomb' 然而
我正在创建一个抽象工具类,该类对另一组外部类(不受我控制)进行操作。外部类在某些接口(interface)点概念上相似,但访问它们相似属性的语法不同。它们还具有不同的语法来应用工具操作的结果。我创建了
这个问题已经有答案了: What do numbers starting with 0 mean in python? (9 个回答) 已关闭 7 年前。 在我的代码中使用按位与运算符 (&) 时,我
我写了这段代码来解析输入文件中的行输入格式:电影 ID 可以有多个条目,所以我们应该计算平均值输出:**没有重复(这是问题所在) import re f = open("ratings2.txt",
我需要处理超过 1000 万个光谱数据集。数据结构如下:大约有 1000 个 .fits(.fits 是某种数据存储格式)文件,每个文件包含大约 600-1000 个光谱,其中每个光谱中有大约 450
我编写了一个简单的 C 程序,它读取一个文件并生成一个包含每个单词及其出现频率的表格。 该程序有效,我已经能够在 Linux 上运行的终端中获得显示的输出,但是,我不确定如何获得生成的显示以生成包含词
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
1.普通的输出: print(str)#str是任意一个字符串,数字··· 2.格式化输出: ?
我无法让 logstash 正常工作。 Basic logstash Example作品。但后来我与 Advanced Pipeline Example 作斗争.也许这也可能是 Elasticsear
这是我想要做的: 我想让用户给我的程序一些声音数据(通过麦克风输入),然后保持 250 毫秒,然后通过扬声器输出。 我已经使用 Java Sound API 做到了这一点。问题是它有点慢。从发出声音到
我是一名优秀的程序员,十分优秀!