Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 1 | include "aos/configuration.fbs"; |
| 2 | |
| 3 | namespace aos.message_bridge; |
| 4 | |
James Kuszmaul | a6681e2 | 2023-05-26 11:20:40 -0700 | [diff] [blame] | 5 | // Per-channel statistics for any channels being forwarded to other nodes by the |
| 6 | // message bridge server. |
| 7 | table ServerChannelStatistics { |
| 8 | // Index into the configuration channels list for this channel. |
| 9 | channel_index:uint64 (id: 0); |
| 10 | // Total number of messages that were sent (this does not necessarily |
| 11 | // mean that the message made it to the client). |
| 12 | sent_packets:uint (id: 1); |
| 13 | // Total number of messages that were dropped while sending (e.g., |
| 14 | // those dropped by the kernel). |
| 15 | dropped_packets:uint (id: 2); |
James Kuszmaul | 79b2f03 | 2023-06-02 21:02:27 -0700 | [diff] [blame] | 16 | // Count of the total number of retries attempted on this channel. |
| 17 | retry_count:uint (id: 3); |
James Kuszmaul | a6681e2 | 2023-05-26 11:20:40 -0700 | [diff] [blame] | 18 | } |
| 19 | |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 20 | // State of the connection. |
| 21 | enum State: ubyte { |
| 22 | CONNECTED, |
| 23 | DISCONNECTED, |
| 24 | } |
| 25 | |
| 26 | // Statistics from a single connection to a client from this server. |
| 27 | table ServerConnection { |
| 28 | // The node that we are connected to. |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 29 | node:Node (id: 0); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 30 | |
| 31 | // Health of this connection. Connected or not? |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 32 | state:State (id: 1); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 33 | |
| 34 | // Number of packets that have been dropped (if known). |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 35 | dropped_packets:uint (id: 2); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 36 | |
Austin Schuh | 40f4c47 | 2021-03-31 21:28:44 -0700 | [diff] [blame] | 37 | // Number of packets sent on all channels. |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 38 | sent_packets:uint (id: 3); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 39 | |
Austin Schuh | 7bc5905 | 2020-02-16 23:48:33 -0800 | [diff] [blame] | 40 | // This is the measured monotonic offset for the connected node in |
| 41 | // nanoseconds. Add this to our monotonic time to get their |
| 42 | // monotonic time. |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 43 | monotonic_offset:int64 (id: 4); |
Austin Schuh | 7bc5905 | 2020-02-16 23:48:33 -0800 | [diff] [blame] | 44 | |
Austin Schuh | 20ac95d | 2020-12-05 17:24:19 -0800 | [diff] [blame] | 45 | // Boot UUID of the client. |
| 46 | boot_uuid:string (id: 5); |
| 47 | |
Austin Schuh | 40f4c47 | 2021-03-31 21:28:44 -0700 | [diff] [blame] | 48 | // Number of extra calls needed to receive a single message |
| 49 | // (indicates congestion) |
| 50 | partial_deliveries:uint (id: 6); |
| 51 | |
Austin Schuh | 367a7f4 | 2021-11-23 23:04:36 -0800 | [diff] [blame] | 52 | // Time at which we connected to the client as nanoseconds on the local |
| 53 | // monotonic clock. This is not populated when not connected, and defaults |
| 54 | // to monotonic_clock::min_time. |
| 55 | connected_since_time:int64 = -9223372036854775808 (id: 7); |
| 56 | |
| 57 | // Number of times we've established a connection to the server. |
| 58 | connection_count:uint (id: 8); |
Austin Schuh | b0e439d | 2023-05-15 10:55:40 -0700 | [diff] [blame] | 59 | |
| 60 | // Number of times we've had an invalid connection with something wrong in |
| 61 | // the connection message, but we were able to match which node it was. |
| 62 | invalid_connection_count:uint (id: 9); |
James Kuszmaul | a6681e2 | 2023-05-26 11:20:40 -0700 | [diff] [blame] | 63 | |
| 64 | // Statistics for every channel being forwarded to this node. Ordering is arbitrary; |
| 65 | // the channels are identified by an index in the ServerChannelStatistics. |
| 66 | channels:[ServerChannelStatistics] (id: 10); |
James Kuszmaul | 79b2f03 | 2023-06-02 21:02:27 -0700 | [diff] [blame] | 67 | |
| 68 | // Total number of retries attempted on all channels. Typically due to kernel |
| 69 | // send buffers filling up. |
| 70 | retry_count:uint (id: 11); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 71 | } |
| 72 | |
| 73 | // Statistics for all connections to all the clients. |
| 74 | table ServerStatistics { |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 75 | connections:[ServerConnection] (id: 0); |
milind | 1f1dca3 | 2021-07-03 13:50:07 -0700 | [diff] [blame] | 76 | |
| 77 | // Count of timestamp send failures |
| 78 | timestamp_send_failures:uint64 (id: 1); |
Austin Schuh | b0e439d | 2023-05-15 10:55:40 -0700 | [diff] [blame] | 79 | |
| 80 | // Number of times we've had an invalid connection with something wrong in |
| 81 | // the connection message. The most likely cause is that the config sha256 |
| 82 | // doesn't match between nodes. |
| 83 | invalid_connection_count:uint (id: 2); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 84 | } |
| 85 | |
| 86 | root_type ServerStatistics; |