可串行化和线性化之间有什么区别?
我对这两种一致性模型感到非常困惑。请给出一些时间线示例并进行解释。 http://en.wikipedia.org/wiki/Consistency_model
I am very confused between these two consistency models. Please give some timeline examples along with explanation.
http://en.wikipedia.org/wiki/Consistency_model
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
很难找到有关这个主题的信息。然而,在某些时候我发现一个说法解释得很清楚:
(根据此处的深入描述进行总结)
举个例子:
这里,A、B、C 是同时运行的三个不同的事务。 r(varname)表示当前事务正在访问varname中的值,w(varname)表示当前事务正在向varname中写入某个值。
现在,为了创建这些事件的线性历史记录,我们必须确保没有两个操作同时发生。当另一个操作已经开始时已经开始的操作应该出现在第一个操作的后面。
在这种情况下:
要创建这些事件的序列化历史记录,必须将事务 A、B 和 C 的所有操作分开,这样就不会与其他事务交错操作。
从我们的示例来看,这可能会导致:
It was hard to find information about this subject. However, At some point I found a statement that explained it clearly:
(summarized from the in-depth description found here)
As an example:
Here, A, B and C are three different transactions running at the same time. r(varname) means that the current transaction is accessing the value inside varname, and w(varname) means that the current transaction is writing a certain value in varname.
Now, to create a linearized history of these events, we have to make sure that no two operations are happening at the same time. An operation that has started while another operation already started should appear behind the first operation.
In this case:
To create a Serialized history of these events, one has to separate all the operations of the transactions A, B and C so there are no interleaved operations from other transactions.
From our example this could result in:
假设您有一个可以对其进行操作的对象。将
事务
定义为您希望对此对象执行的一组操作。令 H 为进程 A、B 和 C 对对象执行的事务调用和响应的以下历史记录。
您可以直观地看到进程 A、B 和 C 正在对对象执行并发操作事务。
如果您假设每个事务在其执行过程中的某个固定点“生效”,则可以将此并发执行“分解”为顺序历史记录。有多种可能的组合: 您可以将事务 B 移至 A 之前或 A 之后。您可以将事务 C 移至 A 之前或 A 之后。您还可以使 B 在 C 之前发生,或 C 在 B 之前发生如果
这些连续历史记录中至少有一个对于正在操作的对象有效,例如,您最终不会从只放入一项的队列中弹出两项,那么该连续历史记录。是序列化 H,并且 H 被认为是可序列化。
请注意,在原始历史记录 H 中,虽然 A 和 B 是并发的,并且 A 和 C 是并发的,但 B 和 C 不是并发的:事务 B 严格在事务 C 开始之前完成。只有在这样的情况下,即一笔交易在另一笔交易开始之前完成,我们可以在历史记录上定义一个顺序:B < C.
如果我们上面列出的一种可能的序列化是有效并且还保留此顺序,那么我们说该序列化是严格序列化 H,并且 H 是严格可序列化的。
这些是 H 的严格序列化,因为在所有这些序列中 B < C.
在所有事务(在本例中为 A、B 和 C)中只有一个操作的特殊情况中,则严格的序列化称为线性化 strong>,并且 H 被称为可线性化。我们之所以给这种特殊情况起一个自己的名字,是因为它具有一般严格可串行性所没有的一些特殊的独特属性:
请注意,严格可串行性意味着可线性化,但反之则不然。
请注意,始终要求生成的顺序历史对于正在操作的对象有效。
请注意,对于给定的历史 H,可以有许多可能的序列化、严格序列化或线性化。
请注意,在本次对话中,我们仅确定特定给定历史 H 的可序列化/线性化。证明特定历史是否可序列化或可线性化很容易。证明某个并发系统中某个对象上的任何历史记录 H 始终是可序列化或线性化的相当困难。
Assume you have an object that you can do operations on. Define
transaction
to be a group of operations you wish to perform on this object.Let H be the following history of transaction invocations and responses performed on your object by processes A, B, and C.
You can visually see processes A, B, and C are executing concurrent transactions of operations on the object.
If you assume that each transaction 'takes effect' at some fixed point in it's execution, you can 'break' apart this concurrent execution into a sequential history. There are multiple possible combinations for this: You can move transaction B to occur before A, or after A. You can move transaction C to occur before A, or after A. You can also make B happen before C, or C happen before B.
If at least one of these sequential histories is valid for the object being operated on, for example you don't end up popping two items from a queue you only put one item into, then that sequential history is a serialization of H, and H is said to be serializable.
Notice that in the original history H, while A and B were concurrent, and A and C were concurrent, B and C were not concurrent: transaction B finished strictly before transaction C started. Only in such a case, where a transaction finished before another one started, we can define an order on the history: B < C.
If one of the possible serializations we listed above is valid and also preserves this order, then we say that that serialization is a strict serialization of H, and H is strictly serializable.
These are the strict serializations of H because in all of them B < C.
In the special case that all of the transactions (in this case A, B, and C) only have a single operation in them, then the strict serialization is called a linearization, and H is said to be linearizable. The reason we give this special case it's own name is because it has some special unique properties that general strict-serializability does not have:
Notice that strict-serializability implies linearizability, but not the other way around.
Notice that it is always a requirement that the resulting sequential history is valid for the object being operated on.
Notice that for a given history H, there can be many possible serializations, strict serializations, or linearizations.
Notice that in this conversation we are only determining serializability/linearizability for a specific given history H. Proving that a specific history is or isn't serializable or linearizable is easy. Proving that any history H in some concurrent system on some object will always be serializable or linearizable is substantially harder.
请观看此视频:https://www.youtube.com/watch? v=noUNH3jDLC0&t
Martin Kleppmann 是《设计数据密集型应用程序》的作者,这是一本很棒的书,我强烈推荐给对可序列化或线性化。
please have a look at this video: https://www.youtube.com/watch?v=noUNH3jDLC0&t
Martin Kleppmann is the writer of Designing Data-Intense Applications which is a great book and I'd highly recommend it to someone interested about either serializability or linearizability.