| ProtoZero |
| --------- |
| |
| *** note |
| **This doc is WIP**, stay tuned. |
| <!-- TODO(primiano): write protozero doc. --> |
| *** |
| |
| ProtoZero is an almost* zero-copy zero-malloc append-only protobuf library. |
| It's designed to be fast and efficient at the cost of a reduced API |
| surface for generated stubs. The main limitations consist of: |
| - Append-only interface: no readbacks are possible from the stubs. |
| - No runtime checks for duplicated or missing mandatory fields. |
| - Mandatory ordering when writing of nested messages: once a nested message is |
| started it must be completed before adding any fields to its parent. |
| |
| *** aside |
| Allocations and library calls will happen only when crossing the boundary of a |
| contiguous buffer (e.g., to request a new buffer to continue the write). |
| Assuming a chunk size (a trace *chunk* is what becomes a *contiguous buffer* |
| within ProtoZero) of 4KB, and an average event size of 32 bytes, only 7 out of |
| 1000 events will hit malloc / ipc / library calls. |
| *** |
| |
| |
| Other resources |
| --------------- |
| * [Design doc](https://goo.gl/EKvEfa]) |