- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 System.IO.Log构建可恢复交易系统的功能。我理解它是在 Common Log File System 之上实现的.
通常ARIES write-ahead logging 的方法涉及在日志以外的地方持久化日志记录序列号(例如,在被记录的操作修改的数据库页面的标题中)。
有趣的是,CLFS 的文档说这样的 sequence numbers are always 64-bit integers .
然而,令人困惑的是,围绕那些 SequenceNumber
的 .Net 包装器s 可以是 constructed from a byte[]
但不是来自 UInt64
。它的值也可以是read as a byte[]
,但不是 UInt64
。检查 SequenceNumber.GetBytes()
的实现表明它实际上可以返回 8 或 16 字节的数组。
这提出了几个问题:
UInt64
,而不是毫无意义地进行短时间的堆分配每次需要写入/读取一个时都使用新的 byte[]
吗?或者,为什么要把 SequenceNumber
变成一个值类型呢?将日志序列号的存储开销加倍似乎是一种奇怪的权衡,这样你就可以拥有超过一百万 TB 的未截断日志,所以我觉得我在这里遗漏了一些东西,或者可能是一些东西。如果有知情人士可以让我直截了当,我将不胜感激。
澄清
我同意 Damien 和 Andras 所说的。到目前为止,这些担忧是对 byte[] 返回类型最可能的解释。但是,在检查反汇编时,CLFS 之上的当前实现具有创建 64 位 LSN 的代码路径和创建 128 位 LSN 的代码路径。为什么?在 CLFS 之上使用 System.IO.Log 的客户端能否安全地将 LSN 存储在固定长度的 64 位字段中? 128 位字段?任意固定长度的字段?
如果 LSN 可以是任意长度,它几乎没有用,因为您需要页眉中某处的 LSN 字段来实现生理逻辑恢复。如果该字段的长度可变,那么寻址页面的非 header 部分的复杂性会显着增加。如果可变长度没有限制,那么您甚至无法确定页面上是否有空间来扩展 LSN header 字段,而不会将 header 或页面内容溢出到新页面,这两者都不是在一般情况下是可行的(因为如果您存储的数据结构甚至允许这种情况,您将检测到这种情况的点远没有您将获得有关如何执行此类恢复的信息的点抽象)。
最佳答案
最明显的原因是因为 UInt64 不符合 CLS,而 System.IO.Log Assembly 被明确标记为 CLSCompliant(true)(在反射器中打开)。
并且由于平台将基础类型定义为 ULONGLONG,因此将结果强制转换为 Int64 是不安全的,因为一半的结果将是负数并且结果空间会回绕。
因此,除了更改 CLS 规范以接受无符号整数之外,最好的解决方案是采用字节数组结果——正如 Damien 所建议的那样,它还具有额外的优势,可以在未来版本的 Windows 扩展它时进行 future 验证返回更多位。
关于.net - 为什么 System.IO.Log SequenceNumbers 具有可变长度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2612423/
这是代码片段。 请说出这种用小内存存储大数据的算法是什么。 public static void main(String[] args) { long longValue = 21474836
所以我使用 imap 从 gmail 和 outlook 接收电子邮件。 Gmail 像这样编码 =?UTF-8?B?UmU6IM69zq3OvyDOtc68zrHOuc67IG5ldyBlbWFpb
很久以前就学会了 C 代码;想用 Scheme 尝试一些新的和不同的东西。我正在尝试制作一个接受两个参数并返回两者中较大者的过程,例如 (define (larger x y) (if (> x
Azure 恢复服务保管库有两个备份配置选项 - LRS 与 GRS 这是一个有关 Azure 恢复服务保管库的问题。 当其驻留区域发生故障时,如何处理启用异地冗余的恢复服务保管库?如果未为恢复服务启
说,我有以下实体: @Entity public class A { @Id @GeneratedValue private Long id; @Embedded private
我有下一个问题。 我有下一个标准: criteria.add(Restrictions.in("entity.otherEntity", getOtherEntitiesList())); 如果我的
如果这是任何类型的重复,我会提前申请,但我找不到任何可以解决我的具体问题的内容。 这是我的程序: import java.util.Random; public class CarnivalGame{
我目前正在使用golang创建一个聚合管道,在其中使用“$ or”运算符查询文档。 结果是一堆需要分组的未分组文档,这样我就可以进入下一阶段,找到两个数据集之间的交集。 然后将其用于在单独的集合中进行
是否可以在正则表达式中创建 OR 条件。 我正在尝试查找包含此类模式的文件名列表的匹配项 第一个案例 xxxxx-hello.file 或者案例二 xxxx-hello-unasigned.file
该程序只是在用户输入行数时创建菱形的形状,因此它有 6 个 for 循环; 3 个循环创建第一个三角形,3 个循环创建另一个三角形,通过这 2 个三角形和 6 个循环,我们得到了一个菱形,这是整个程序
我有一个像这样的查询字符串 www.google.com?Department=Education & Finance&Department=Health 我有这些 li 标签,它们的查询字符串是这样
我有一个带有静态构造函数的类,我用它来读取 app.config 值。如何使用不同的配置值对类进行单元测试。我正在考虑在不同的应用程序域中运行每个测试,这样我就可以为每个测试执行静态构造函数 - 但我
我正在寻找一个可以容纳多个键的容器,如果我为其中一个键值输入保留值(例如 0),它会被视为“或”搜索。 map, int > myContainer; myContainer.insert(make_
我正在为 Web 应用程序创建数据库,并正在寻找一些建议来对可能具有多种类型的单个实体进行建模,每种类型具有不同的属性。 作为示例,假设我想为“数据源”对象创建一个关系模型。所有数据源都会有一些共享属
(1) =>CREATE TABLE T1(id BIGSERIAL PRIMARY KEY, name TEXT); CREATE TABLE (2) =>INSERT INTO T1 (name)
我不确定在使用别名时如何解决不明确的列引用。 假设有两个表,a 和 b,它们都有一个 name 列。如果我加入这两个表并为结果添加别名,我不知道如何为这两个表引用 name 列。我已经尝试了一些变体,
我的查询是: select * from table where id IN (1,5,4,3,2) 我想要的与这个顺序完全相同,不是从1...5,而是从1,5,4,3,2。我怎样才能做到这一点? 最
我正在使用 C# 代码执行动态生成的 MySQL 查询。抛出异常: CREATE TABLE dump ("@employee_OID" VARCHAR(50)); "{"You have an er
我有日期 2016-03-30T23:59:59.000000+0000。我可以知道它的格式是什么吗?因为如果我使用 yyyy-MM-dd'T'HH:mm:ss.SSS,它会抛出异常 最佳答案 Sim
我有一个示例模式,它的 SQL Fiddle 如下: http://sqlfiddle.com/#!2/6816b/2 这个 fiddle 只是根据 where 子句中的条件查询示例数据库,如下所示:
我是一名优秀的程序员,十分优秀!