- 介绍
- 介绍 - 资料收集整理
- 安装 - Linux单机部署
- 官方文档(翻译)
- 官方文档(翻译) - 开发指南
- 开发指南 - 搭建本地集群
- 开发指南 - 和etcd交互
- 开发指南 - API 参考文档
- 开发指南 - API 并发参考文档
- 开发指南 - gRPC 网关
- 开发指南 - gRPC命名与发现
- 开发指南 - 试验性的API和特性
- 开发指南 - 系统限制
- 官方文档(翻译) - 操作etcd集群
- 操作etcd集群 - 搭建etcd集群
- 搭建etcd集群 - 运行时重配置
- 搭建etcd集群 - 运行时重配置的设计
- 操作etcd集群 - 搭建etcd网关
- 操作etcd集群 - 在容器内运行etcd集群
- 操作etcd集群 - 配置
- 操作etcd集群 - 加密(TODO)
- 操作etcd集群 - 维护
- 操作etcd集群 - 理解失败
- 操作etcd集群 - 灾难恢复
- 操作etcd集群 - 性能
- 操作etcd集群 - 版本
- 操作etcd集群 - 支持平台
- 官方文档(翻译) - 学习
- 学习 - 理解数据模型
- 学习 - 理解API
- 学习 - 术语
- 学习 - API保证
- API参考文档(翻译)
- API参考文档(翻译) - KV service
- KV service - Range方法
- KV service - Put方法
- KV service - DeleteRange方法
- KV service - Txn方法
- KV service - Compact方法
- API参考文档(翻译) - Watch service
- Watch service - Watch方法
- API参考文档(翻译) - Lease service
- Lease service - LeaseGrant方法
- Lease service - LeaseRevoke方法
- Lease service - LeaseKeepAlive方法
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
KV service - Txn方法
Txn 方法在单个事务中处理多个请求。
一个 txn 请求增加键值存储的修订版本并为每个完成的请求生成带有相同修订版本的事件。
不容许在一个txn中多次修改同一个key。
rpc Txn(TxnRequest) returns (TxnResponse) {}
背景
以下内容翻译来自 proto文件中 TxnRequest 的注释,解释了Txn请求的工作方式.
来自 google paxosdb 论文:
我们的实现围绕强大的我们称为 MultiOp 的原生(primitive)。所有除了循环外的其他数据库操作被实现为对 MultiOp 的单一调用。MultiOp 被原子性的应用并由三个部分组成:
- 被称为guard的测试列表。在guard中每个测试检查数据库中的单个项(entry)。它可能检查某个值的存在或者缺失,或者和给定的值比较。在guard中两个不同的测试可能应用于数据库中相同或者不同的项。guard中的所有测试被应用然后 MultiOp 返回结果。如果所有测试是true,MultiOp 执行 t 操作 (见下面的第二项), 否则它执行 f 操作 (见下面的第三项).
- 被称为 t 操作的数据库操作列表. 列表中的每个操作是插入,删除,或者查找操作,并应用到单个数据库项。列表中的两个不同操作可能应用到数据库中相同或者不同的项。如果 guard 评价为true 这些操作将被执行
- 被成为 f 操作的数据库操作列表. 类似 t 操作, 但是是在 guard 评价为 false 时执行。
消息体
请求的消息体是 TxnRequest:
message TxnRequest {
// compare 是断言列表,体现为条件的联合。
// 如果比较成功,那么成功请求将被按顺序处理,而应答将按顺序包含他们对应的应答。
// 如果比较失败,那么失败请求将被按顺序处理,而应答将按顺序包含他们对应的应答。
repeated Compare compare = 1;
// 成功请求列表,当比较评估为 true 时将被应用。
repeated RequestOp success = 2;
// 失败请求列表,当比较评估为 false 时将被应用。
repeated RequestOp failure = 3;
}
应答的消息体是 TxnResponse:
message TxnResponse {
ResponseHeader header = 1;
// 如果比较评估为true则succeeded被设置为true,否则是false
bool succeeded = 2;
// 应答列表,如果 succeeded 是 true 则对应成功请求,如果 succeeded 是 false 则对应失败请求
repeated ResponseOp responses = 3;
}
Compare 消息体:
message Compare {
enum CompareResult {
EQUAL = 0;
GREATER = 1;
LESS = 2;
}
enum CompareTarget {
VERSION = 0;
CREATE = 1;
MOD = 2;
VALUE= 3;
}
// result是这个比较的逻辑比较操作
CompareResult result = 1;
// target是比较要检查的键值字段
CompareTarget target = 2;
// key是用于比较操作的主题key
bytes key = 3;
oneof target_union {
// version是给定key的版本
int64 version = 4;
// create_revision 是给定key的创建修订版本
int64 create_revision = 5;
// mod_revision 是给定key的最后修改修订版本
int64 mod_revision = 6;
// value 是给定key的值,以bytes的形式
bytes value = 7;
}
}
RequestOp 消息体:
message RequestOp {
// request 是可以被事务接受的请求类型的联合
oneof request {
RangeRequest request_range = 1;
PutRequest request_put = 2;
DeleteRangeRequest request_delete_range = 3;
}
}
ResponseOp 消息体:
message ResponseOp {
// response 是事务返回的应答类型的联合
oneof response {
RangeResponse response_range = 1;
PutResponse response_put = 2;
DeleteRangeResponse response_delete_range = 3;
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论