The Plasma Object Store provides a server process, reference C++ client, and Python binding for managing a collection of binary "objects" in POSIX shared memory. Applications use a lightweight messaging protocol to create and delete memory blocks in the object store, evict objects to make room for new objects, and increment and decrement reference counts to indicate shared ownership of memory. It also provides for subscribing to notifications about object activity. The system helps simplify ownership transfer and memory lifetime of shared memory blocks, which can be much more complicated in a peer-to-peer architecture.
The object store has been used in conjunction with the Apache Arrow libraries to provide for zero-copy access to collections of large objects stored in shared memory. Incorporating this project into Apache Arrow will help the community continue to develop and innovate technology for low-overhead sharing of complex datasets across multiple processes.
The Apache Arrow PMC will be responsible for the code.
It will be integrated into the Apache Arrow project, into the C++ part of the main Arrow source tree and build system.
The following people will be managing this contribution:
Completed tasks are shown by the completion date (YYYY-MM-dd).
date | item |
---|---|
2017-07-27 | Trademark and Google Search found no use of name as software product. |
date | item |
---|---|
2017-07-27 | Check and make sure that the files that have been donated have been updated to reflect the new ASF copyright. |
Identify name recorded for software grant: arrow-plasma-object-store
Corporations and individuals holding existing distribution rights:
date | item |
---|---|
2017-07-27 | Check that all active committers have a signed CLA on record. |
2017-07-27 | Remind active committers that they are responsible for ensuring that a Corporate CLA is recorded if such is required to authorize their contributions under their individual CLA. |
2017-07-27 | Check and make sure that for all items included with the distribution that is not under the Apache license, we have the right to combine with Apache-licensed code and redistribute. |
2017-07-27 | Check and make sure that all items depended upon by the project is covered by one or more of the following approved licenses: Apache, BSD, Artistic, MIT/X, MIT/W3C, MPL 1.1, or something with essentially the same terms. |
Generally, the result of checking off these items will be a Software Grant, CLA, and Corporate CLA for ASF licensed code, which must have no dependencies upon items whose licenses that are incompatible with the Apache License.