首页 > 其他分享 > Project #4 - Concurrency Control 题目要求

Project #4 - Concurrency Control 题目要求

时间:2023-04-20 22:02:06浏览次数:43  
标签:Control txn 事务 transaction lock Project manager Concurrency id

OVERVIEW

这个项目是关于在 BusTub 中增加对事务的支持!为了实现这个目标,你将在你的数据库系统中添加一个 lock manager,然后用它来支持并发查询的执行。lock manager 负责跟踪 tables 和 tuples 上的 lock,有五种不同的模式:intention-shared, intention-exclusive, shared-intention-exclusive, shared, and exclusive。lock manager 将处理来自事务的锁请求,向事务授予锁,并根据事务的隔离级别检查锁是否被适当释放。

PROJECT SPECIFICATION

本项目的正确性取决于你对以前项目的实现是否正确;除了 Project #3 中的 B+ Tree wrapper 外,我们不会提供解决方案或二进制文件。

Task #1 - Lock Manager

为确保事务操作的正确并发,DBMS 将使用 Lock Manager (LM) 来控制何时允许事务访问数据项。 LM 的基本思想是它维护一个由当前 active 事务持有的 lock 的内部数据结构。 事务在允许访问数据项之前要向 LM 发出锁请求。 LM 将选择:授予该事务锁 / block 该事务 / abort 该事务。

在你的实现中,整个系统将有一个全局 LM (类似于 buffer pool manager)。每当一个事务想要访问/修改一个 tuple 时,TableHeapExecutor 类将使用 LM 来获取 tuple records (by record id RID) 的锁。

这项任务要求你实现一个 table-level 和 tuple-level 的 LM,支持三种常见的隔离级别:READ_UNCOMMITEDREAD_COMMITTED,和 REPEATABLE_READ。Lock Manager 应根据事务的隔离级别授予或释放锁。请参考 lecture slides ,了解隔离级别的复习情况。

我们为你提供了一个 Transaction context handle (include/concurrency/transaction.h),其中有一个隔离级别属性 (i.e., READ_UNCOMMITED, READ_COMMITTED, and REPEATABLE_READ) 以及关于其获取的 locks 的信息。LM 将需要检查事务的隔离级别,并在 lock/unlock 请求上做出正确的行为。任何失败的锁操作都应该导致 ABORTED 事务状态 (隐式 abort ) 并抛出一个异常。transaction manager (include/concurrency/transaction_manager.h) 将进一步捕捉这个异常,并回滚由事务执行的写操作。

我们推荐你阅读这篇文章以回顾C++并发知识。这里有更详细的文档。

REQUIREMENTS

Task1 中你只需要修改LockManager 类 (concurrency/lock_manager.cpp and include/concurrency/lock_manager.h)。需要实现以下函数:

  • LockTable(Transaction, LockMode, TableOID)
  • UnlockTable(Transction, TableOID)
  • LockRow(Transaction, LockMode, TableOID, RID)
  • UnlockRow(Transaction, TableOID, RID)

lock manager 采取的具体锁机制取决于事务隔离级别,是 table-level lock 还是 tuple-level lock,以及涉及的锁的类型。你应该先看一下 transaction.hlock_manager.h ,熟悉我们提供的 API 和成员变量。然后,仔细阅读 [LOCK_NOTE], [UNLOCK_NOTE], 以及 lock_manager.h 中的各个函数规范,了解你的 LM 的预期行为。

我们还建议回顾一下隔离级别和 hierarchical locking 的概念,因为这些函数的实现应与提出锁定/解锁请求的事务的隔离级别兼容。你可以在 lock_manager.h 中自由添加任何必要的数据结构。你应该参考教科书中的 Chapters 15.1-15.2 和 Lecture 中涉及的隔离级别概念,以确保你的实现满足要求。

HINTS

  • 虽然你的 Lock Manager 需要使用死锁检测,但我们建议在添加检测机制之前,先测试和验证你的 Lock Manager 实现的正确性,不需要任何死锁处理。
  • 你将需要一些方法来跟踪哪些事务正在等待一个锁。看看 LockRequestQueue class in lock_manager.h
  • 什么时候需要升级一个锁?当你需要更新 table/tuple lock 时,需要对 LockRequestQueue 进行哪些操作?
  • 当有锁竞争时,你将需要某种方式来通知正在等待的事务。我们推荐使用作为 LockRequestQueue 的一部分提供的 std::condition_variable
  • 你应该维护一个事务的状态。例如,由于解锁操作,事务的状态可能从 GROWING 阶段变为 SHRINKING 阶段 (提示:查看 transaction.h 中的方法)。
  • 你还应该使用*_lock_set_ 跟踪事务获得的锁,这样当 TransactionManager 想要 commit/abort 事务时,LM 可以正确地释放这些锁。
  • 将一个事务的状态设置为 ABORTED 隐式 abort 了该事务,但直到 TransactionManager::Abort 被调用时才会显式地 abort。你应该通读这个函数和提供的测试,以了解它的作用,以及你的 lock manager 在 abort过程中是如何使用的。

Task #2 - Deadlock Detection

你的 lock manager 应该在后台运行死锁检测,以中止阻塞的事务。

更确切地说,这意味着一个后台线程应该定期地在运行中建立一个 waits-for 图,并打破任何循环。

REQUIREMENTS

你必须实现并用于你的周期检测以及测试的 graph API是如下:

  • AddEdge(txn_id_t t1, txn_id_t t2): 在你的图中添加一条从t1到t2的边。如果这条边已经存在,你不必做任何事情。
  • RemoveEdge(txn_id_t t1, txn_id_t t2): 从你的图中删除边t1到t2。如果不存在这样的边,你不必做任何事情。
  • HasCycle(txn_id_t& txn_id): 通过使用深度优先搜索 (DFS) 算法来寻找一个 cycle。如果找到一个 cycle,HasCycle 应该在 txn_id 中存储该 cycle 中最年轻的 transaction id,并返回 true。你的函数应该返回它找到的第一个 cycle。如果你的图没有循环,HasCycle 应该返回 false。
  • GetEdgeList(): 返回一个代表你的图中的边的 tuple list。我们将用它来测试你的图形的正确性。(t1,t2) pair 对应于从 t1 到 t2 的一条边。
  • RunCycleDetection(): 包含在后台运行周期检测的骨架代码。你应该在这里实现你的周期检测逻辑。

NOTES

  • 你的后台线程应该在每次唤醒时都建立 graph。你不应该维护一个 graph,它应该在每次线程唤醒时被建立和销毁。
  • 你的DFS周期检测算法必须是确定性的。为了做到这一点,你必须总是选择首先探索最低的 transaction id。这意味着当选择哪个未探索的节点来运行 DFS 时,总是选择具有最低 transaction id 的节点。这也意味着在探索邻居时,要按照从低到高的排序来探索它们。
  • 当你发现一个 cycle 时,应中止最年轻的 transaction,通过将该 transaction 的状态设置为 ABORTED 来打破 cycle。
  • 当你的检测线程被唤醒时,它负责打破所有存在的 cycle。如果你遵循上述要求,你将总是以确定的顺序找到循环。这也意味着,当你构建你的 graph 时,你不应该为 aborted 的事务添加节点,也不应该为 aborted 的事务画边。
  • 你的后台检测算法可能要获取一个事务的指针 txn_id,我们增加了一个静态方法 Transaction* GetTransaction(txn_id_t txn_id) 来让你做这个。
  • 你可以使用 std::this_thread::sleep_for 来排序线程来编写测试案例。你也可以在测试用例中调整 common/config.h 中的 CYCLE_DETECTION_INTERVAL

HINTS

  • A waits for graph is a directed graph.
  • 当一个事务在等待另一个事务时,waits for graphe 会画一条边。请记住,如果多个事务在同一个对象上持有锁,一个事务可能在等待多个事务。
  • 当一个事务被中止时,请确保将该事务的状态设置为 ABORTED。transaction manager 将处理明确的 abort 和 rollback。
  • 一个等待锁的事务可能会被后台周期检测线程中止。你必须有办法通知等待中的事务他们已经被中止了。

Task #3 - Concurrent Query Execution

Leaderboard Task (Optional)

INSTRUCTIONS

本地测试

$ cd build
$ make lock_manager_test
$ make deadlock_detection_test
$ make transaction_test
$ ./test/lock_manager_test
$ ./test/deadlock_detection_test
$ ./test/transaction_test

SUBMISSION

make format
make check-lint
make check-clang-tidy-p4

标签:Control,txn,事务,transaction,lock,Project,manager,Concurrency,id
From: https://www.cnblogs.com/angelia-wang/p/17338510.html

相关文章

  • scrapy startproject tutorial 这句话在哪输入cmd?
    大家好,我是皮皮。一、前言前几天在Python钻石交流群【未央.】问了一个Python网络爬虫的问题,这里拿出来给大家分享下。课程截图如下:官网的截图如下:二、实现过程这里【甯同学】给了提示,不过对于新手来说,还是不太容易上手的。进入终端之后,我们再启动项目,如下:正常来说,这样就可以启动成......
  • Build was configured to prefer settings repositories over project repositories b
    首先上链接:stackoverflow的正解下载了最新版的狐狸图标的AS,4.1.2版本,新建的项目默认使用的最新版本7.0.2的gradle, 在项目的build.gradle中添加项目编译需要的依赖,allprojects{repositories{google()jcenter()}} 然后,报错,编译不过。提示也说了,构建被配......
  • 关于报错:Error adding module to project: setSdk: sdk '1.8' type 'JavaSDK' is not
    问题描述:Erroraddingmoduletoproject:setSdk:sdk'1.8'type'JavaSDK'isnotregisteredinProjectJdkTable(图片来自贴吧,看到有一个人问这个问题,然后自己碰到了但是忘了截图)说明当前项目在“ProjectJdkTable”里面是没有配置sdk1.8的。百度翻译过来就是:未在Project......
  • 提高kafka消费速度之从源码去了解Spring-kafka的concurrency参数
    网上看到这篇文章,觉得很不错,这里转载记录一下。转自:提高kafka消费速度之从源码去了解Spring-kafka的concurrency参数-简书第一部分、引言    在spring应用中,如果我们需要订阅kafka消息,通常情况下我们不会直接使用kafka-client,而是使用了更方便的一层封装spring-kafk......
  • ASP.NET没有魔法——ASP.NET MVC Controller的实例化与执行
    原文:https://www.cnblogs.com/selimsong/p/7677108.html上一章节中对路由的注册和匹配过程进行了介绍,知道了MVC的Http请求最终是交由MvcHandler处理的,而其处理过程就是对Controller的创建、执行和释放。本章将从以下几点进一步对上面提到的三个过程进行介绍:●MvcHand......
  • Oracle 恢复之using backup controlfile 和 until cancel
    Oracle恢复数据库时有几个常用但非常相似的命令,整理下它们各自的作用及适用场景。recoverdatabaserecoverdatabaseuntilcancelrecoverdatabaseusingbackupcontrolfilerecoverdatabaseusingbackupcontrolfileuntilcancelrecoverdatabaseuntilcancelusingbackupc......
  • ArcPy 批处理之 [ hdf转tif ]; [ Con函数 ]; 镶嵌至新栅格 [ Mosaic to New Raster ];
    一、 ArcPy批量将文件夹内的*.hdf文件转为*.tif 文件:#encoding:utf-8 ##hdf2tifimportarcpyimportosinPath=r'E:\Data\S00_DataHdf\\'outPath=r'E:\Data\S01_DataTif\\'fordirpath,dirnames,filenamesinos.walk(inPath):......
  • 启动SSH服务报:Job for ssh.service failed because the control process exited with
    Jobforssh.servicefailedbecausethecontrolprocessexitedwitherrorcodeseesystemctlstatusssh.serviceandjournalctl-xefordetails.然后按照提示输入:systemctlstatussshd.service 表示给出的提示很坑爹,完全不知道哪里出错了。经过艰难的百度,可能是SELI......
  • [TV][技术名词][TCON]Timing Controller,时序控制芯片
    TCON:TimingControllerTED:TCONEmbededDriverICTDDI:TouchandDisplayDriverICIntegratedTCONless:将TCON的功能集成到SoC中。普通电视:采用TCONless设计。高端电视:采用分离TCON的方案,确保画质。平板电脑:此类中尺寸显示屏类产品,主要将TCON和Driver集成,即TED。手机:此类......
  • @RestControllerAdvice注解 @ExceptionHandler注解
    RestControllerAdvice+ExceptionHandler这两个注解的组合,被用作项目的全局异常处理。一旦项目中发生了异常,就会进入使用了RestControllerAdvice注解类中使用了ExceptionHandler注解的方法。下面是一些项目全局异常的处理@ControllerAdvice(annotations={RestController.class,......