Show simple item record

dc.contributor.advisorKaashoek, M. Frans
dc.contributor.advisorZeldovich, Nickolai
dc.contributor.advisorChajed, Tej
dc.contributor.authorTheng, Mark
dc.date.accessioned2022-06-15T13:07:30Z
dc.date.available2022-06-15T13:07:30Z
dc.date.issued2022-02
dc.date.submitted2022-02-22T18:32:25.308Z
dc.identifier.urihttps://hdl.handle.net/1721.1/143253
dc.description.abstractBugs related to concurrency and crash safety are infamous for being subtle and hard to reproduce. Formal verification provides a way to combat such bugs through the use of machine-checked proofs about program behavior. However, reasoning about concurrency and crashes can be tricky, especially when scaling up to larger systems that must also have good performance. This thesis discusses the verification of GoTxn, the concurrent, crash-safe transaction system underlying the verified Network File System (NFS) server DaisyNFS. It focuses on the specification and proof of the write-ahead log and the automatic two-phase locking interface used to enforce crash and concurrent atomicity in transactions, detailing how the verification framework Perennial can be used to manage assertions about crash behavior across multiple threads. By effectively harnessing concurrency to hide disk access latency, GoTxn enables performance in DaisyNFS similar to the unverified Linux NFS server.
dc.publisherMassachusetts Institute of Technology
dc.rightsIn Copyright - Educational Use Permitted
dc.rightsCopyright MIT
dc.rights.urihttp://rightsstatements.org/page/InC-EDU/1.0/
dc.titleGoTxn: Verifying a Crash-Safe, Concurrent Transaction System
dc.typeThesis
dc.description.degreeM.Eng.
dc.contributor.departmentMassachusetts Institute of Technology. Department of Electrical Engineering and Computer Science
mit.thesis.degreeMaster
thesis.degree.nameMaster of Engineering in Electrical Engineering and Computer Science


Files in this item

Thumbnail

This item appears in the following Collection(s)

Show simple item record