Programming Persistent Memory : : A Comprehensive Guide for Developers / / by Steve Scargall.
Beginning and experienced programmers will use this comprehensive guide to persistent memory programming. You will understand how persistent memory brings together several new software/hardware requirements, and offers great promise for better performance and faster application startup times—a huge...
Saved in:
VerfasserIn: | |
---|---|
Place / Publishing House: | Berkeley, CA : : Apress :, Imprint: Apress,, 2020. |
Year of Publication: | 2020 |
Edition: | 1st ed. 2020. |
Language: | English |
Physical Description: | 1 online resource (XXXI, 438 p. 104 illus.) |
Tags: |
Add Tag
No Tags, Be the first to tag this record!
|
id |
993544301904498 |
---|---|
ctrlnum |
(CKB)4900000000505202 (DE-He213)978-1-4842-4932-1 (oapen)https://directory.doabooks.org/handle/20.500.12854/26322 (CaSebORM)9781484249321 (PPN)242849083 (EXLCZ)994900000000505202 |
collection |
bib_alma |
record_format |
marc |
spelling |
Scargall, Steve. author. aut http://id.loc.gov/vocabulary/relators/aut Programming Persistent Memory : A Comprehensive Guide for Developers / by Steve Scargall. 1st ed. 2020. Berkeley, CA : Apress : Imprint: Apress, 2020. 1 online resource (XXXI, 438 p. 104 illus.) text txt rdacontent computer c rdamedia online resource cr rdacarrier English Open Access Chapter 1: Introduction to Persistent Memory Programming -- Chapter 2: Persistent Memory Architecture -- Chapter 3: Operating System Support for Persistent Memory -- Chapter 4: Fundamental Concepts of Persistent Memory Programming -- Chapter 5: Introducing the Persistent Memory Development Kit -- Chapter 6: libpmem: Low-Level Persistent Memory Support -- Chapter 7: libpmemobj - A Native Transactional Object Store -- Chapter 8: libpmemobj-cpp: The adaptable language C++ and Persistent Memory -- Chapter 9: pmemkv - A Persistent In-Memory Key-Value Store -- Chapter 10: Volatile Use of Persistent Memory -- Chapter 11: Designing Data Structures for Persistent Memory -- Chapter 12: Debugging Persistent Memory Applications -- Chapter 13: Enabling Persistence in a Real World Application -- Chapter 14: Concurrency and Persistent Memory -- Chapter 15: Profiling and Performance -- Chapter 16: PMDK Internals - Important Algorithms and Data Structures -- Chapter 17: Reliability, Availability and Serviceability -- Chapter 18: Remote Persistent Memory -- Chapter 19: Advanced Topics -- Appendix A: Installing NDCTL and DAXCTL on Linux -- Appendix B: Installing PMDK on Linux & Windows -- Appendix C: Installing IPMCTL on Linux and Windows -- Appendix D: Java for Persistent Memory -- Appendix E: The Future of Remote Persistent Memory Replocation. Beginning and experienced programmers will use this comprehensive guide to persistent memory programming. You will understand how persistent memory brings together several new software/hardware requirements, and offers great promise for better performance and faster application startup times—a huge leap forward in byte-addressable capacity compared with current DRAM offerings. This revolutionary new technology gives applications significant performance and capacity improvements over existing technologies. It requires a new way of thinking and developing, which makes this highly disruptive to the IT/computing industry. The full spectrum of industry sectors that will benefit from this technology include, but are not limited to, in-memory and traditional databases, AI, analytics, HPC, virtualization, and big data. Programming Persistent Memory describes the technology and why it is exciting the industry. It covers the operating system and hardware requirements as well as how to create development environments using emulated or real persistent memory hardware. The book explains fundamental concepts; provides an introduction to persistent memory programming APIs for C, C++, JavaScript, and other languages; discusses RMDA with persistent memory; reviews security features; and presents many examples. Source code and examples that you can run on your own systems are included. You will: Understand what persistent memory is, what it does, and the value it brings to the industry Become familiar with the operating system and hardware requirements to use persistent memory Know the fundamentals of persistent memory programming: why it is different from current programming methods, and what developers need to keep in mind when programming for persistence Look at persistent memory application development by example using the Persistent Memory Development Kit (PMDK) Design and optimizedata structures for persistent memory Study how real-world applications are modified to leverage persistent memory Utilize the tools available for persistent memory programming, application performance profiling, and debugging. Computer networks. Big data. Computer Communication Networks. Big Data. 1-4842-4931-3 |
language |
English |
format |
eBook |
author |
Scargall, Steve. Scargall, Steve. |
spellingShingle |
Scargall, Steve. Scargall, Steve. Programming Persistent Memory : A Comprehensive Guide for Developers / Chapter 1: Introduction to Persistent Memory Programming -- Chapter 2: Persistent Memory Architecture -- Chapter 3: Operating System Support for Persistent Memory -- Chapter 4: Fundamental Concepts of Persistent Memory Programming -- Chapter 5: Introducing the Persistent Memory Development Kit -- Chapter 6: libpmem: Low-Level Persistent Memory Support -- Chapter 7: libpmemobj - A Native Transactional Object Store -- Chapter 8: libpmemobj-cpp: The adaptable language C++ and Persistent Memory -- Chapter 9: pmemkv - A Persistent In-Memory Key-Value Store -- Chapter 10: Volatile Use of Persistent Memory -- Chapter 11: Designing Data Structures for Persistent Memory -- Chapter 12: Debugging Persistent Memory Applications -- Chapter 13: Enabling Persistence in a Real World Application -- Chapter 14: Concurrency and Persistent Memory -- Chapter 15: Profiling and Performance -- Chapter 16: PMDK Internals - Important Algorithms and Data Structures -- Chapter 17: Reliability, Availability and Serviceability -- Chapter 18: Remote Persistent Memory -- Chapter 19: Advanced Topics -- Appendix A: Installing NDCTL and DAXCTL on Linux -- Appendix B: Installing PMDK on Linux & Windows -- Appendix C: Installing IPMCTL on Linux and Windows -- Appendix D: Java for Persistent Memory -- Appendix E: The Future of Remote Persistent Memory Replocation. |
author_facet |
Scargall, Steve. Scargall, Steve. |
author_variant |
s s ss s s ss |
author_role |
VerfasserIn VerfasserIn |
author_sort |
Scargall, Steve. |
title |
Programming Persistent Memory : A Comprehensive Guide for Developers / |
title_sub |
A Comprehensive Guide for Developers / |
title_full |
Programming Persistent Memory : A Comprehensive Guide for Developers / by Steve Scargall. |
title_fullStr |
Programming Persistent Memory : A Comprehensive Guide for Developers / by Steve Scargall. |
title_full_unstemmed |
Programming Persistent Memory : A Comprehensive Guide for Developers / by Steve Scargall. |
title_auth |
Programming Persistent Memory : A Comprehensive Guide for Developers / |
title_new |
Programming Persistent Memory : |
title_sort |
programming persistent memory : a comprehensive guide for developers / |
publisher |
Apress : Imprint: Apress, |
publishDate |
2020 |
physical |
1 online resource (XXXI, 438 p. 104 illus.) |
edition |
1st ed. 2020. |
contents |
Chapter 1: Introduction to Persistent Memory Programming -- Chapter 2: Persistent Memory Architecture -- Chapter 3: Operating System Support for Persistent Memory -- Chapter 4: Fundamental Concepts of Persistent Memory Programming -- Chapter 5: Introducing the Persistent Memory Development Kit -- Chapter 6: libpmem: Low-Level Persistent Memory Support -- Chapter 7: libpmemobj - A Native Transactional Object Store -- Chapter 8: libpmemobj-cpp: The adaptable language C++ and Persistent Memory -- Chapter 9: pmemkv - A Persistent In-Memory Key-Value Store -- Chapter 10: Volatile Use of Persistent Memory -- Chapter 11: Designing Data Structures for Persistent Memory -- Chapter 12: Debugging Persistent Memory Applications -- Chapter 13: Enabling Persistence in a Real World Application -- Chapter 14: Concurrency and Persistent Memory -- Chapter 15: Profiling and Performance -- Chapter 16: PMDK Internals - Important Algorithms and Data Structures -- Chapter 17: Reliability, Availability and Serviceability -- Chapter 18: Remote Persistent Memory -- Chapter 19: Advanced Topics -- Appendix A: Installing NDCTL and DAXCTL on Linux -- Appendix B: Installing PMDK on Linux & Windows -- Appendix C: Installing IPMCTL on Linux and Windows -- Appendix D: Java for Persistent Memory -- Appendix E: The Future of Remote Persistent Memory Replocation. |
isbn |
1-4842-4932-1 1-4842-4931-3 |
callnumber-first |
T - Technology |
callnumber-subject |
TK - Electrical and Nuclear Engineering |
callnumber-label |
TK5105 |
callnumber-sort |
TK 45105.5 45105.9 |
illustrated |
Not Illustrated |
dewey-hundreds |
000 - Computer science, information & general works |
dewey-tens |
000 - Computer science, knowledge & systems |
dewey-ones |
004 - Data processing & computer science |
dewey-full |
004.6 |
dewey-sort |
14.6 |
dewey-raw |
004.6 |
dewey-search |
004.6 |
work_keys_str_mv |
AT scargallsteve programmingpersistentmemoryacomprehensiveguidefordevelopers |
status_str |
n |
ids_txt_mv |
(CKB)4900000000505202 (DE-He213)978-1-4842-4932-1 (oapen)https://directory.doabooks.org/handle/20.500.12854/26322 (CaSebORM)9781484249321 (PPN)242849083 (EXLCZ)994900000000505202 |
carrierType_str_mv |
cr |
is_hierarchy_title |
Programming Persistent Memory : A Comprehensive Guide for Developers / |
_version_ |
1801159555476881409 |
fullrecord |
<?xml version="1.0" encoding="UTF-8"?><collection xmlns="http://www.loc.gov/MARC21/slim"><record><leader>05161nam a22004935i 4500</leader><controlfield tag="001">993544301904498</controlfield><controlfield tag="005">20240313224644.0</controlfield><controlfield tag="006">m o d </controlfield><controlfield tag="007">cr#nn#008mamaa</controlfield><controlfield tag="008">200109s2020 xxu| o |||| 0|eng d</controlfield><datafield tag="020" ind1=" " ind2=" "><subfield code="a">1-4842-4932-1</subfield></datafield><datafield tag="024" ind1="7" ind2=" "><subfield code="a">10.1007/978-1-4842-4932-1</subfield><subfield code="2">doi</subfield></datafield><datafield tag="035" ind1=" " ind2=" "><subfield code="a">(CKB)4900000000505202</subfield></datafield><datafield tag="035" ind1=" " ind2=" "><subfield code="a">(DE-He213)978-1-4842-4932-1</subfield></datafield><datafield tag="035" ind1=" " ind2=" "><subfield code="a">(oapen)https://directory.doabooks.org/handle/20.500.12854/26322</subfield></datafield><datafield tag="035" ind1=" " ind2=" "><subfield code="a">(CaSebORM)9781484249321</subfield></datafield><datafield tag="035" ind1=" " ind2=" "><subfield code="a">(PPN)242849083</subfield></datafield><datafield tag="035" ind1=" " ind2=" "><subfield code="a">(EXLCZ)994900000000505202</subfield></datafield><datafield tag="041" ind1="0" ind2=" "><subfield code="a">eng</subfield></datafield><datafield tag="050" ind1=" " ind2="4"><subfield code="a">TK5105.5-5105.9</subfield></datafield><datafield tag="072" ind1=" " ind2="7"><subfield code="a">UKN</subfield><subfield code="2">bicssc</subfield></datafield><datafield tag="072" ind1=" " ind2="7"><subfield code="a">COM075000</subfield><subfield code="2">bisacsh</subfield></datafield><datafield tag="072" ind1=" " ind2="7"><subfield code="a">UKN</subfield><subfield code="2">thema</subfield></datafield><datafield tag="082" ind1="0" ind2="4"><subfield code="a">004.6</subfield><subfield code="2">23</subfield></datafield><datafield tag="100" ind1="1" ind2=" "><subfield code="a">Scargall, Steve.</subfield><subfield code="e">author.</subfield><subfield code="4">aut</subfield><subfield code="4">http://id.loc.gov/vocabulary/relators/aut</subfield></datafield><datafield tag="245" ind1="1" ind2="0"><subfield code="a">Programming Persistent Memory :</subfield><subfield code="b">A Comprehensive Guide for Developers /</subfield><subfield code="c">by Steve Scargall.</subfield></datafield><datafield tag="250" ind1=" " ind2=" "><subfield code="a">1st ed. 2020.</subfield></datafield><datafield tag="264" ind1=" " ind2="1"><subfield code="a">Berkeley, CA :</subfield><subfield code="b">Apress :</subfield><subfield code="b">Imprint: Apress,</subfield><subfield code="c">2020.</subfield></datafield><datafield tag="300" ind1=" " ind2=" "><subfield code="a">1 online resource (XXXI, 438 p. 104 illus.)</subfield></datafield><datafield tag="336" ind1=" " ind2=" "><subfield code="a">text</subfield><subfield code="b">txt</subfield><subfield code="2">rdacontent</subfield></datafield><datafield tag="337" ind1=" " ind2=" "><subfield code="a">computer</subfield><subfield code="b">c</subfield><subfield code="2">rdamedia</subfield></datafield><datafield tag="338" ind1=" " ind2=" "><subfield code="a">online resource</subfield><subfield code="b">cr</subfield><subfield code="2">rdacarrier</subfield></datafield><datafield tag="546" ind1=" " ind2=" "><subfield code="a">English</subfield></datafield><datafield tag="506" ind1="0" ind2=" "><subfield code="a">Open Access</subfield></datafield><datafield tag="505" ind1="0" ind2=" "><subfield code="a">Chapter 1: Introduction to Persistent Memory Programming -- Chapter 2: Persistent Memory Architecture -- Chapter 3: Operating System Support for Persistent Memory -- Chapter 4: Fundamental Concepts of Persistent Memory Programming -- Chapter 5: Introducing the Persistent Memory Development Kit -- Chapter 6: libpmem: Low-Level Persistent Memory Support -- Chapter 7: libpmemobj - A Native Transactional Object Store -- Chapter 8: libpmemobj-cpp: The adaptable language C++ and Persistent Memory -- Chapter 9: pmemkv - A Persistent In-Memory Key-Value Store -- Chapter 10: Volatile Use of Persistent Memory -- Chapter 11: Designing Data Structures for Persistent Memory -- Chapter 12: Debugging Persistent Memory Applications -- Chapter 13: Enabling Persistence in a Real World Application -- Chapter 14: Concurrency and Persistent Memory -- Chapter 15: Profiling and Performance -- Chapter 16: PMDK Internals - Important Algorithms and Data Structures -- Chapter 17: Reliability, Availability and Serviceability -- Chapter 18: Remote Persistent Memory -- Chapter 19: Advanced Topics -- Appendix A: Installing NDCTL and DAXCTL on Linux -- Appendix B: Installing PMDK on Linux & Windows -- Appendix C: Installing IPMCTL on Linux and Windows -- Appendix D: Java for Persistent Memory -- Appendix E: The Future of Remote Persistent Memory Replocation.</subfield></datafield><datafield tag="520" ind1=" " ind2=" "><subfield code="a">Beginning and experienced programmers will use this comprehensive guide to persistent memory programming. You will understand how persistent memory brings together several new software/hardware requirements, and offers great promise for better performance and faster application startup times—a huge leap forward in byte-addressable capacity compared with current DRAM offerings. This revolutionary new technology gives applications significant performance and capacity improvements over existing technologies. It requires a new way of thinking and developing, which makes this highly disruptive to the IT/computing industry. The full spectrum of industry sectors that will benefit from this technology include, but are not limited to, in-memory and traditional databases, AI, analytics, HPC, virtualization, and big data. Programming Persistent Memory describes the technology and why it is exciting the industry. It covers the operating system and hardware requirements as well as how to create development environments using emulated or real persistent memory hardware. The book explains fundamental concepts; provides an introduction to persistent memory programming APIs for C, C++, JavaScript, and other languages; discusses RMDA with persistent memory; reviews security features; and presents many examples. Source code and examples that you can run on your own systems are included. You will: Understand what persistent memory is, what it does, and the value it brings to the industry Become familiar with the operating system and hardware requirements to use persistent memory Know the fundamentals of persistent memory programming: why it is different from current programming methods, and what developers need to keep in mind when programming for persistence Look at persistent memory application development by example using the Persistent Memory Development Kit (PMDK) Design and optimizedata structures for persistent memory Study how real-world applications are modified to leverage persistent memory Utilize the tools available for persistent memory programming, application performance profiling, and debugging.</subfield></datafield><datafield tag="650" ind1=" " ind2="0"><subfield code="a">Computer networks.</subfield></datafield><datafield tag="650" ind1=" " ind2="0"><subfield code="a">Big data.</subfield></datafield><datafield tag="650" ind1="1" ind2="4"><subfield code="a">Computer Communication Networks.</subfield></datafield><datafield tag="650" ind1="2" ind2="4"><subfield code="a">Big Data.</subfield></datafield><datafield tag="776" ind1=" " ind2=" "><subfield code="z">1-4842-4931-3</subfield></datafield><datafield tag="906" ind1=" " ind2=" "><subfield code="a">BOOK</subfield></datafield><datafield tag="ADM" ind1=" " ind2=" "><subfield code="b">2024-06-07 01:42:47 Europe/Vienna</subfield><subfield code="f">system</subfield><subfield code="c">marc21</subfield><subfield code="a">2020-01-11 22:13:25 Europe/Vienna</subfield><subfield code="g">false</subfield></datafield><datafield tag="AVE" ind1=" " ind2=" "><subfield code="i">DOAB Directory of Open Access Books</subfield><subfield code="P">DOAB Directory of Open Access Books</subfield><subfield code="x">https://eu02.alma.exlibrisgroup.com/view/uresolver/43ACC_OEAW/openurl?u.ignore_date_coverage=true&portfolio_pid=5337573130004498&Force_direct=true</subfield><subfield code="Z">5337573130004498</subfield><subfield code="b">Available</subfield><subfield code="8">5337573130004498</subfield></datafield></record></collection> |