Title | Serializable Snapshot Isolation in PostgreSQL |
Publication Type | Journal Article |
Year of Publication | 2012 |
Authors | Ports DRK, Grittner K |
Journal | Proceedings of the VLDB Endowment |
Volume | 5 |
Pagination | 1850–1861 |
Abstract | This paper describes our experience implementing PostgreSQL's new serializable isolation level. It is based on the recently-developed Serializable Snapshot Isolation (SSI) technique. This is the first implementation of SSI in a production database release as well as the first in a database that did not previously have a lock-based serializable isolation level. We reflect on our experience and describe how we overcame some of the resulting challenges, including the implementation of a new lock manager, a technique for ensuring memory usage is bounded, and integration with other PostgreSQL features. We also introduce an extension to SSI that improves performance for read-only transactions. We evaluate PostgreSQL's serializable isolation level using several benchmarks and show that it achieves performance only slightly below that of snapshot isolation, and significantly outperforms the traditional two-phase locking approach on read-intensive workloads. |
Downloads | http://drkp.net/papers/ssi-vldb12.pdf |
Citation Key | ports12:_serial_snaps_isolat_postg |